And*_*zos 32 c++ templates c++11
假设我有一个模板功能:
template<typename T>
void f(T t)
{
...
}
Run Code Online (Sandbox Code Playgroud)
我想为所有原始整数类型编写一个专门化.做这个的最好方式是什么?
我的意思是:
template<typename I where is_integral<I>::value is true>
void f(I i)
{
...
}
Run Code Online (Sandbox Code Playgroud)
并且编译器为整数类型选择第二个版本,为其他所有类型选择第一个版本?
Dav*_*vid 48
使用SFINAE
// For all types except integral types:
template<typename T>
typename std::enable_if<!std::is_integral<T>::value>::type f(T t)
{
// ...
}
// For integral types only:
template<typename T>
typename std::enable_if<std::is_integral<T>::value>::type f(T t)
{
// ...
}
Run Code Online (Sandbox Code Playgroud)
请注意,std::enable_if
即使是声明,您也必须包含完整的返回值.
Joh*_*itb 24
我会使用重载决议.这使您不必使用SFINAE总体黑客.不幸的是,有许多领域你无法避免它,但幸运的是这不是其中之一.
template<typename T>
void f(T t)
{
f(t, std::is_integral<T>());
}
template<typename T>
void f(T t, std::true_type)
{
// ...
}
template<typename T>
void f(T t, std::false_type)
{
// ...
}
Run Code Online (Sandbox Code Playgroud)
arn*_*noo 11
使用c ++ 11,std :: enable_if(http://en.cppreference.com/w/cpp/types/enable_if)可以用来做到这一点:
template<typename T, class = typename std::enable_if<std::is_integral<T>::value>::type>
void f(T t) {...}
Run Code Online (Sandbox Code Playgroud)
这是 C++20 解决方案
template<std::integral T>
void f(T v) {
...
}
Run Code Online (Sandbox Code Playgroud)
我认为它实际上是重载函数,但工作原理相同。
您可以使用可以像这样专门化的帮助程序模板:
#include <string>
#include <iostream>
#include <type_traits>
template <typename T, bool = std::is_integral<T>::value>
struct Foo {
static void bar(const T& t) { std::cout << "generic: " << t << "\n"; }
};
template <typename T>
struct Foo<T, true> {
static void bar(const T& t) { std::cout << "integral: " << t << "\n"; }
};
template <typename T>
static void bar(const T& t) {
return Foo<T>::bar(t);
}
int main() {
std::string s = "string";
bar(s);
int i = 42;
bar(i);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
输出:
generic: string
integral: 42
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
15621 次 |
最近记录: |