Pertanyaan yang diberi tag «typetraits»

5
Bagaimana cara kerja `is_base_of`?
Bagaimana cara kerja kode berikut? typedef char (&yes)[1]; typedef char (&no)[2]; template <typename B, typename D> struct Host { operator B*() const; operator D*(); }; template <typename B, typename D> struct is_base_of { template <typename T> static yes check(D*, T); static no check(B*, int); static const bool value = sizeof(check(Host<B,D>(), …



1
std :: is_constructible mengembalikan nilai yang tidak konsisten untuk konstruktor pribadi
Apa aturan yang std::is_constructiblemenangani konstruktor pribadi? Diberikan kode berikut: #include <iostream> class Class { private: Class() { } }; template <typename T> class Test { public: static void test() { std::cout //<< std::is_constructible<Class>::value << std::is_constructible<T>::value << std::endl; } }; int main() { Test<Class>::test(); } Cetakan ini 0( ideone ), yaitu, …
13 c++  typetraits 

1
Mengapa static_cast diperlukan dalam implementasi gcc dari is_nothrow_constructible?
Diambil dari implementasi GCC type_traitsmengapa static_castdiperlukan di sini? template <typename _Tp, typename... _Args> struct __is_nt_constructible_impl : public integral_constant<bool, noexcept(_Tp(declval<_Args>()...))> {}; template <typename _Tp, typename _Arg> struct __is_nt_constructible_impl<_Tp, _Arg> : public integral_constant<bool, // Why is `static_cast` needed here? noexcept(static_cast<_Tp>(declval<_Arg>()))> {};

3
Mengapa tidak perlu menggunakan nama samaran untuk jenis tergantung dalam kasus berikut?
Saya telah membaca tentang menghapus referensi jenis, di sini . Ini memberi contoh berikut: #include <iostream> // std::cout #include <type_traits> // std::is_same template<class T1, class T2> void print_is_same() { std::cout << std::is_same<T1, T2>() << '\n'; } int main() { std::cout << std::boolalpha; print_is_same<int, int>(); print_is_same<int, int &>(); print_is_same<int, int &&>(); …
Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.