为模板专用化选择字符串文本类型
Selecting string literal type for template specialization
我正在尝试使用模板专用化,以便我可以对不同类型的行为进行专用行为。 但是,我无法获得字符串文本类型(const char[N]
)的模板专用化以绑定到专用模板。
我有一个简单的模板select_type<T>
,具有以下专业:
template <class T>
struct select_type
{
static void action()
{
cout << "Generic type" << endl;
}
};
template <>
struct select_type<std::string>
{
static void action()
{
cout << "Specialization for string" << endl;
}
};
template <std::size_t N>
struct select_type<const char[N]>
{
static void action()
{
cout << "Specialization for const char array" << endl;
}
};
当我尝试按如下方式实例化每个专用化时:
select_type<int>::action();
select_type<std::string>::action();
select_type<decltype("abc")>::action();
。我得到以下输出:
Generic type
Specialization for string
Generic type
请注意,不会调用char
数组的专用化,即使decltype(abc)
应该生成类型 const char[4]
。
我认为可能正在发生某种类型的衰减,所以我添加了const char*
的专用化,但仍然没有被选中。
那么,为什么表达式:
select_type<decltype("abc")>::action();
无法调用const char[N]
的专用化?
您
看到此行为是因为decltype
如何推断类型。字符串文本是左值。来自 [expr.prim.general]/p1:
字符串文本是左值;所有其他文本都是 prvalues。
decltype()
返回左值的左值引用类型。[dcl.type.simple]/p4
对于表达式
e
,用decltype(e)
表示的类型定义如下:(4.1) — 如果
e
是无括号的 id 表达式或无括号的类成员访问 (5.2.5),则decltype(e)
是e
命名的实体的类型。如果没有这样的实体,或者e
命名一组重载函数, 程序格式不正确;(4.2) — 否则,如果
e
是 x值,则decltype(e)
T&&
,其中T
是e
的类型;(4.3) — 否则,如果
e
是左值,则decltype(e)
T&
,其中T
是e
的类型;(4.4) — 否则,
decltype(e)
是e
的类型。
所以你的专业需要如下:
template <std::size_t N>
struct select_type<const char (&)[N]>
相关文章:
- 如何在C++中用std::cout正确显示带十六进制的字符串文本
- 在编译时检查字符串文本的长度
- 读取字符串文本输入以创建 2D 矢量
- 管理字符串文本的最佳做法
- 定义宏以将前缀 0x 添加到十六进制字符串文本
- 无法在模板参数中定义字符串文本
- 不推荐使用 PTCHAR 的字符串文本
- C++ 字符串文本和常量
- C++20字符串文本模板参数工作示例
- 返回从字符串文本创建的静态string_view是否安全?
- 在处理任何字符大小的模板中使用字符串文本
- 是否保证相同内容字符串文本的存储相同?
- 将以 null 结尾的字节字符串转换为原始字符串文本
- 是否可以创建一个用户定义的文本,将字符串文本转换为 own 类型的数组?
- 使用C++中的模板检测不同的字符串文本
- 无法完全专用化字符串文本的模板
- C++ - 确定 const char* 是指向字符串文本对象还是动态对象
- 是否可以在原始字符串文本中插入转义序列?
- C++带有捕获组的正则表达式字符串文本
- 为什么多维数组中的空字符串文本衰减为空指针?