C++类型的trait来提取模板参数的特殊化值
C++ type trait to extract specialization value of template argument
我有以下模板:
template<typename T, const char *name_ >
struct named {
typedef T type;
static constexpr const char *name = name_;
};
我想有以下类型的特征:
- 如果参数类型为"named",将提取类型和名称(2个不同)
- 如果参数不同,将提取原始类型和空字符串类型
示例:
template<typename T>
void foo() {
typename cppdi::extract_type<T>::type x;
std::cout << "type: " << typeid(x).name() <<
", name: " << cppdi::extract_name<T>::value << std::endl;
}
char bar[] = "bar";
void test() {
foo<int>(); // type: i, name:
foo<named<int, bar>>(); // type: i, name: bar
}
有可能实现这样的extract_type
和extract_name
吗?
这样写你的特征:
template< typename T >
struct extract_type
{ using type = T; };
template< typename T, const char* S >
struct extract_type< named< T, S > >
{ using type = T; };
template< typename T >
struct extract_name
{ static constexpr const char* value = ""; };
template< typename T, const char* S >
struct extract_name< named< T, S > >
{ static constexpr const char* value = S; };
单凭这一点是行不通的,你提供的代码在很多地方都是非法的。我在这个实例中修复了它们。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- C++类型的trait来提取模板参数的特殊化值
- 基于类模板参数特殊化c++成员函数