Parameter
相关链接
代码文件:
参考示例:
接口概述
AimRT 中提供了一个简单的模块级 Key-Val 参数功能,模块可以通过调用CoreRef
句柄的GetParameterHandle()
接口,获取aimrt::parameter::ParameterHandleRef
句柄,来使用此功能。该句柄提供的核心接口如下:
namespace aimrt::parameter {
class ParameterHandleRef {
public:
std::string GetParameter(std::string_view key) const;
void SetParameter(std::string_view key, std::string_view val) const;
};
} // namespace aimrt::parameter
使用注意点如下:
std::string GetParameter(std::string_view key)
接口:用于获取参数。如果不存在 key,则返回空字符串。
该接口是线程安全的。
void SetParameter(std::string_view key, std::string_view val)
接口:用于设置/更新参数。如果不存在 key,则新建一个 key-val 参数对。
如果存在 key,则更新 key 所对应的 val 值为最新值。
该接口是线程安全的。
无论是设置参数还是获取参数,都是模块级别的,不同模块的参数互相独立、互不可见。
除了通过 CPP 接口中的参数接口来设置/获取参数,使用者也可以通过 parameter_plugin,通过 HTTP 等方式来从外部设置/获取参数。具体请参考parameter_plugin 文档。
使用示例
一个简单的使用示例如下:
class HelloWorldModule : public aimrt::ModuleBase {
public:
bool Initialize(aimrt::CoreRef core) override {
auto parameter_handle = core.GetParameterHandle();
std::string key = "test key";
std::string val = "test val";
// Set
parameter_handle.SetParameter(key, val);
// Get
std::string check_val = parameter_handle.GetParameter(key);
assert(val == check_val);
return true;
}
};