晚上好,
我在专门化可变参数模板时遇到问题。我需要以下模板:
template<typename... Ts>
using OPT = decltype(operator+(std::declval<Ts>()...))(Ts...);
问题是,当我尝试使用时,这无法编译
OTP<double,double>
所以我尝试通过它进行特化
template<>
using OPT<double,double> = double;
但现在我收到错误
error: expected unqualified-id before ‘using’
using OPT<double,double> = double;
有谁知道解决这个问题的方法还是我做错了什么?
感谢您的阅读和帮助!
最佳答案
您需要一个幕后的结构来实现这一点,因为别名模板无法专门化,也无法引用自身。
#include <utility>
template<typename T, typename... Ts>
struct sum_type {
using type = decltype(std::declval<T>() + std::declval<typename sum_type<Ts...>::type>());
};
template <typename T>
struct sum_type<T> {
using type = T;
};
template<typename... Ts>
using OPT = typename sum_type<Ts...>::type;
关于c++ - 使用特殊化可变参数模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39396516/