将外部库中的定义隐藏到我的代码中

Hide define from external library to my code

本文关键字:我的 代码 隐藏 外部 定义      更新时间:2023-10-16

对于我当前的C++项目,我使用来自第三方的外部库(1 个大标题)。此标头提供多个类似 C 的函数来驱动硬件。为了使其更容易在C++中使用,我编写了一个 C++ 类来包装这些函数并使用 pimpl 实现隐藏此标头。 这些函数的某些参数由预处理器指令定义,#define在其主标头中。我想在我的包装类之外使用这些参数的值,但不包含此标头。

我尝试在C++类中使用前向声明的枚举。但是我的枚举成员在定义它们的源文件之外不可用

external_lib.h

#define PARAM_A_VAL_0 0
#define PARAM_A_VAL_1 1
bool external_function_param_a(int param_a);

包装器.h

class wrapper
{
enum PARAM_A : int;
...
bool SetParamA(wrapper::PARAM_A a);
}

包装纸.cpp

#include <wrapper.h>
#include <external_lib.h>
enum wrapper::PARAM_A: int
{
VAL_0 = PARAM_A_VAL_0,
VAL_1 = PARAM_A_VAL_1
};
bool wrapper SetParamA(wrapper::PARAM_A a)
{
return external_function_param_a(a);
}

主.cpp

#include <wrapper.h>
int main()
{
wrapper w;
w.SetParamA(wrapper::PARAM_A::VAL_0);   
// compilation error : VAL_0 not a member of wrapper::PARAM_A
}

我的解决方案有问题还是这个想法是不可能的?有没有更好的解决方案。为类包装器创建大量成员似乎不是一个好主意,也不是在所有函数成员中打开枚举的开关。

如果你必须保持编译时常量,你将无法避免包含外部标头,如本问答中所述。

如果编译时常量不是必需的,则可以将wrapper::PARAM_A::VAL_NNN常量的声明和定义分开,如下所示:

页眉:

struct wrapper {
class PARAM_A {
int val;
PARAM_A(int val) : val(val) {}
friend class ::wrapper;
public:
static const PARAM_A VAL_0;
static const PARAM_A VAL_1;
};
bool SetParamA(wrapper::PARAM_A a);
};

实现:

const wrapper::PARAM_A wrapper::PARAM_A::VAL_0 = wrapper::PARAM_A(PARAM_A_VAL_0);
const wrapper::PARAM_A wrapper::PARAM_A::VAL_1 = wrapper::PARAM_A(PARAM_A_VAL_1);
bool wrapper::SetParamA(wrapper::PARAM_A a)
{
return external_function_param_a(a.val);
}

现在,API 的使用与示例中相同:

wrapper w;
w.SetParamA(wrapper::PARAM_A::VAL_0);
w.SetParamA(wrapper::PARAM_A::VAL_1);

演示。

请注意类PARAM_A隐藏int值的方式:由于它不再是enum,因此不再可能直接使用代替int,因此对external_function_param_a的调用需要"解包"值。

相关文章: