模板定义的宏
Macro for template definitions
本文关键字:定义 更新时间:2023-10-16
我对别名模板有问题,因为我的代码必须与不支持别名模板的VS 2012兼容。
假设我有一个别名模板,如下所示:
template<typename A, typename B> using foo = bar<A,B>;
那么能够执行以下操作将非常方便:
#ifdef NO_ALIAS_TEMPLATE_AVAILABLE
#define foo<x,y> bar<x,y>
#else
template<typename A, typename B> using foo = bar<A,B>;
#endif
然而,我能做的最好的事情是
#define foo(x,y) bar<x,y>
而且,为了提高代码的可读性,我不想用圆括号替换所有代码中的所有模板专用化。
有没有办法让带有分隔符的宏<>
用于其参数?还是我的问题没有简单的解决方案?如果没有,如何实现与别名模板的严格等效?
不,预处理器不能使用 <>
来分隔宏参数。
您可以使用类模板模拟别名模板:
template <typename A, typename B>
struct foo {
typedef bar<A, B> type;
};
// Usage: foo<A, B>::type
// Generic context: typename foo<A, B>::type
演示
这将使它的用法变得不那么好,但这是不可避免的。
以下更简单的解决方案对我有用。
#ifdef NO_ALIAS_TEMPLATE_AVAILABLE
#define foo bar
#else
template<typename A, typename B> using foo = bar<A,B>;
#endif
鉴于
template <typename A, typename B> struct bar {};
以下行工作正常。
foo<int, double> f; // Ok.
bar<int, double> b; // Ok.
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 部分定义/别名模板模板参数
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- #为""定义宏;静态";针对不同的上下文
- 如何确保C++函数在定义之前声明(如override关键字)
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在命名空间中定义函数还是限定函数
- 此代码是否违反一个定义规则
- 编译C++时未定义的引用
- 不同翻译单元中不可重载的非内联函数定义
- 为什么在定义函数之前先声明它
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 使用用户定义函数的字符串反转
- 用户定义函数中的指针和输入
- vscode g++链路故障:体系结构x86_64的未定义符号
- 如何定义一个纯抽象基类