使用static_assert确保最多只能使用 *模板参数
Use static_assert to ensure template parameter is only used *at most* once
是否可以确保(或最多都可以使用模板参数的组合(来确保某个模板参数(或模板参数的组合(一次?是否可以跟踪使用次数的次数,如果使用多次,则可以丢下static_assert错误?
作为一个例子 - 假设我想创建一个基于静态模板的GPIO类:
template<uint8_t Port, uint8_t Pin> class Gpio {};
一个人可以在单板类中铺设整个板:
struct Board {
Gpio<1, 1> myInputPin;
Gpio<1, 2> myOutputPin;
Gpio<2, 0> ledR;
Gpio<2, 1> ledG;
Gpio<2, 2> ledB;
};
对于任何给定的端口/引脚组合,对于该端口和销钉进行实例化的A GPIO模板才有意义。如果某人为同一端口/PIN组合创建了两个不同的GPIO实例,则可能代表冲突,我想在编译过程中捕获此错误。
这是可能的吗?
您可以用宏解决此问题:
#define GPIO(Port, Pin)
friend void _gpio_ ## Port ## _ ## Pin(){}
Gpio<Port, Pin>
然后,如果您两次使用GPIO(2, 2)
,则编译器会说这样的话:
error: redefinition of '_gpio_2_2'
GPIO(2, 2) ledX;
^
<source>:14:3: note: previous definition is here
GPIO(2, 2) ledB;
^
演示:https://godbolt.org/z/ronv0u
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 具有非类型参数的类模板的静态成员的 gdb "static field value has been optimized out"
- 为什么在 C++ 中将函数作为参数传递给 pthread 时会出现"non-static member function"错误?