由於問題已修改且允許使用C++ 11,因此我幾乎從cppreference發佈了一個複製粘貼,沒有任何功勞。
namespace detail {
struct nonesuch {
nonesuch() = delete;
~nonesuch() = delete;
nonesuch(nonesuch const&) = delete;
void operator=(nonesuch const&) = delete;
};
template <class Default, class AlwaysVoid, template <class...> class Op, class... Args>
struct detector {
using value_t = std::false_type;
using type = Default;
};
template <typename... Ts>
struct my_make_void {
typedef void type;
};
template <typename... Ts>
using my_void_t = typename my_make_void<Ts...>::type;
template <class Default, template <class...> class Op, class... Args>
struct detector<Default, my_void_t<Op<Args...>>, Op, Args...> {
using value_t = std::true_type;
using type = Op<Args...>;
};
} // namespace detail
template <template <class...> class Op, class... Args>
using is_detected =
typename detail::detector<detail::nonesuch, void, Op, Args...>::value_t;
template <class T>
using copy_assign_t = decltype(std::declval<T&>() = std::declval<const T&>());
struct Meow {};
struct Purr {
void operator=(const Purr&) = delete;
};
int main() {
cerr << is_detected<copy_assign_t, Meow>::value << endl;
return 0;
}
爲什麼不能在C++ 03中實現'void_t'? – Justin
@Justin因爲C++ 03沒有可變參數模板參數。 –
@RichardHodges是的,我知道。你不能實現一個可變參數'void_t',但是你可以很容易地創建一個非可變參數。如果C++ - 03沒有可變參數模板,你不能完全創建一個可變參數'is_detected',但是你可以,例如,只爲一個參數做 – Justin