67 lines
2.2 KiB
Markdown
67 lines
2.2 KiB
Markdown
# Parameter
|
||
|
||
## 相关链接
|
||
|
||
代码文件:
|
||
- {{ '[aimrt_module_cpp_interface/parameter/parameter_handle.h]({}/src/interface/aimrt_module_cpp_interface/parameter/parameter_handle.h)'.format(code_site_root_path_url) }}
|
||
|
||
参考示例:
|
||
- {{ '[parameter_module.cc]({}/src/examples/cpp/parameter/module/parameter_module/parameter_module.cc)'.format(code_site_root_path_url) }}
|
||
|
||
|
||
## 接口概述
|
||
|
||
AimRT 中提供了一个简单的模块级 Key-Val 参数功能,模块可以通过调用`CoreRef`句柄的`GetParameterHandle()`接口,获取`aimrt::parameter::ParameterHandleRef`句柄,来使用此功能。该句柄提供的核心接口如下:
|
||
|
||
```cpp
|
||
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 文档](../plugins/parameter_plugin.md)。
|
||
|
||
## 使用示例
|
||
|
||
一个简单的使用示例如下:
|
||
```cpp
|
||
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;
|
||
}
|
||
};
|
||
```
|
||
|