有没有办法为模板化函数声明类型名
Is There a Way to Declare a typename for a Templatized Function?
所以,我有这个模板化的函数(我知道它看起来很丑陋。
不过,我的意图不是默认模板参数,我的目的是创建一个派生自T
的typename
,该可用于用户无法分配的caster
。
我的问题是如何为用户无法作为参数传递的模板化函数创建typename
?
举个例子:
template <typename T>
typename R = std::conditional<sizeof(T) == 4, char, short>;
R foo(T bar){return R(bar);}
显然,这段代码无法编译,但这就是我想要完成的行为。函子是唯一的方法吗?
在 C++14 中,使用返回类型推导可以优雅地解决这个问题。
// C++14
#include <type_traits>
template <typename T>
decltype(auto)
foo(T bar)
{
using R = std::conditional_t<sizeof(T) == 4, char, short>;
return static_cast<R>(bar);
}
在 C++11 中,您必须重复类型计算。
// C++11
#include <type_traits>
template <typename T>
typename std::conditional<sizeof(T) == 4, char, short>::type
foo(T bar)
{
using R = typename std::conditional<sizeof(T) == 4, char, short>::type;
return static_cast<R>(bar);
}
这可以通过使用decltype
来找出类型来缩短一点。
// C++11
#include <type_traits>
template <typename T>
typename std::conditional<sizeof(T) == 4, char, short>::type
foo(T bar)
{
using R = decltype(foo(bar));
return static_cast<R>(bar);
}
但坦率地说,使用简单的默认类型参数有什么问题?
// C++11
#include <type_traits>
template <typename T,
typename R = typename std::conditional<sizeof(T) == 4, char, short>::type>
R
foo(T bar)
{
return static_cast<R>(bar);
}
请注意,我已将 return
语句中 R
的值初始化替换为一个static_cast
,以静音编译器关于缩小转换的警告。 不过,您确定这是您想要的吗?
一种可能性是使用using
类型别名而不是typename
。以下代码在我测试的编译器上编译(记住启用-std=c++11
标志(。
#include <type_traits>
#include <iostream>
// C++11
template <typename T>
using R = typename std::conditional<sizeof(T) == 4, char, short>::type;
template <typename T>
R<T> foo(T bar){return R<T>(bar);}
int main() {
std::cout << foo(13.0) << std::endl;
return 0;
}
在 C++14 中,您可以使用 conditional_t
特征,这更简单。
// C++14
template <typename T>
using R = std::conditional_t<sizeof(T) == 4, char, short>;
相关文章:
- Visual Studio中的函数声明和函数定义问题
- 为什么函数声明中允许 const?
- 如果 x.h 仅由函数声明组成,为什么有必要在 x 中包含 x.h.cpp
- * 和 ** 在 C++ 函数声明中是什么意思?
- 构造函数/函数声明参数列表中的统一初始化
- 在将函数声明为友元时,尖括号的含义是什么?
- 为什么转换函数声明不需要至少一个定义类型说明符
- 如何正确编写指针函数声明?
- 在"template"和函数声明之间使用:template<typename trait> using tr = base_trait<trait> void fn(tr::t
- 为什么要将函数声明和定义放在单独的文件中
- 为什么系统日志有两个不同的函数声明?
- 我如何获取数组的大小,以便我可以从函数声明所述数组
- 使用 enable_if 在按值传递与按引用传递之间更改函数声明
- JavaScript 中的一等函数和 C++ 中的函数声明
- C++ 通过函数声明后初始化向量
- VS2017 #error: : snprintf 的宏定义与标准库函数声明冲突
- C++ 17 个友元函数声明和内联命名空间
- MSVC 2017 - 错误 - 如何将模板类 X 的模板成员函数声明为嵌套类 X::Y 的好友
- 将派生类的构造函数声明为父类的友元
- 用于从 ANSI 字符串转换为 std::basic_string <TCHAR>的正确函数声明