- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个宏,用于对具有继承构造函数的模板进行自动子类型化,如下所示:
#define INST_TMPL(NAME,TMPL,...) \
struct NAME : public TMPL<__VA_ARGS__> { \
typedef TMPL<__VA_ARGS__> Base;\
using Base::Base;\ // Inherit constructors
};
请不要争论这样的宏是否必要或良好的风格。对我们的项目很有帮助;我们用它来缩短非常长的模板的类型名称。例如,我们可以将模板名称缩短为 LongName<int,float,x::y::LongInnerType>
通过使用 INST_TMPL(MyType,LongName,int,float,x::y::LongInnerType)
.现在我们可以简单地使用 MyType
而不是长模板,类型也将显示在错误消息中(而不是扩展模板名称)。
但现在有一个问题:根据使用的模板,我们有时需要 typename
在typedef
宏里面。例如,如果使用的模板是模板参数 T
的内部模板,例如T::LongName<...>
, 那么我们需要 typename
在 typedef 中,即:
typedef typename TMPL<__VA_ARGS__> Base;\
当然,我可以创建两个宏,一个带有 typename
和一个没有。然而,这是相当麻烦的。相反,我希望有一个在两种情况下都能正确编译的宏。这可能吗?
最佳答案
来自评论:
重写这里的方法 typename
可以通过宏参数指定是使用一个辅助模板类,它只报告它自己的模板参数。
template <typename T>
struct id { typedef T type; };
#define INST_TMPL(NAME,...) \
struct NAME : id<__VA_ARGS__>::type { \
typedef typename id<__VA_ARGS__>::type Base; \
using Base::Base; \
};
像INST_IMPL(MyType,LongName<int,float,x::y::LongInnerType>)
一样使用它,或喜欢 INST_IMPL(MyType,typename T::LongName<int,float,x::y::LongInnerType>)
.
typename id<...>::type
的使用即使这是非依赖类型也是允许的。
关于必要时插入类型名称的 C++ 宏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26233807/
我正在使用 this solution在二进制矩阵中找到与图像边界对齐的矩形。假设现在我想找到一个不与图像边框对齐的矩形,并且我不知道它的方向;找到它的最快方法是什么? 为了示例,让我们寻找一个仅包含
else: 行在这个 Python 程序中是否正确/必要? from random import randrange for n in range(10): r = randrange(0,1
在 TDPL 7.1.5.1 中讨论了将 Widget w2 分配给 w1 并且作者指出“将 w2 逐个字段分配给 w1 会将 w2.array 分配给 w1.array——一个简单的数组边界分配,而
我是一名优秀的程序员,十分优秀!