所以这个传奇中的另一个问题。Guillaume Racicot已经足够好,可以为我提供另一种解决方法,所以这是我提出这个问题的代码:
struct vec
{
double x;
double y;
double z;
};
namespace details
{
template <typename T>
using subscript_function = double(*)(const T&);
template <typename T>
constexpr double X(const T& param) { return param.x; }
template <typename T>
constexpr double Y(const T& param) { return param.y; }
template <typename T>
constexpr double Z(const T& param) { return param.z; }
}
template <typename T, typename = void>
constexpr details::subscript_function<T> my_temp[] = { &details::X<T>, &details::Y<T> };
template <typename T>
constexpr details::subscript_function<T> my_temp<T, enable_if_t<is_floating_point_v<decltype(details::X(T()))>, T>>[] = { &details::X<T>, &details::Y<T>, &details::Z<T> };
int main() {
vec foo = { 1.0, 2.0, 3.0 };
for(const auto i : my_temp<decltype(foo)>) {
cout << (*i)(foo) << endl;
}
}
当我返回除. void
例如,在上面的代码中,enable_if_t<is_floating_point_v<decltype(details::X(T()))>, T>
防止特化,而简单地删除最后一个参数并允许enable_if
返回void
允许特化。
我认为这表明我对这里真正发生的事情的误解。为什么必须始终使用专门的类型才能void
使其正常工作?