Dalam pembangunan kod, selalunya perlu untuk menentukan kehadiran pembolehubah ahli tertentu dalam kelas. Maklumat ini amat berguna untuk mencipta fungsi templat algoritma generik yang beroperasi pada pelbagai kelas dengan nama ahli yang berbeza.
Memandangkan kelas sebagai hujah templat, matlamatnya adalah untuk memastikan sama ada ia mempunyai pembolehubah ahli tertentu, dilambangkan dengan sama ada "x" atau "X" (atau huruf besar mereka). Keupayaan ini akan memudahkan penciptaan algoritma generik yang mengendalikan sistem koordinat yang berbeza, seperti kelas CPoint MFC atau PointF GDI.
Untuk menangani isu ini, templat boleh dilaksanakan yang menerima kelas sebagai hujah templat dan menyemak kehadiran pembolehubah ahli yang dikehendaki. Dengan memanfaatkan saiz operator dan ciri jenis, adalah mungkin untuk membezakan antara kewujudan pembolehubah ahli "x" dan "X".
Berikut ialah contoh pelaksanaan:
template<int> struct TT { typedef int type; }; template<class P> bool Check_x(P p, typename TT<sizeof(&P::x)>::type b = 0) { return true; } template<class P> bool Check_x(P p, typename TT<sizeof(&P::X)>::type b = 0) { return false; }
Templat ini berfungsi dengan membandingkan saiz &P::x dan &P::X untuk menentukan pembolehubah ahli mana yang hadir. Jika &P::x wujud, templat kembali benar; jika tidak, ia mengembalikan palsu.
Penyelesaian yang dicadangkan serasi dengan Visual Studio dan GNU C . Walau bagaimanapun, untuk pendekatan yang lebih universal, penyelesaian menggunakan ciri jenis C 11 boleh digunakan:
#include <type_traits> template <typename T, typename = int> struct HasX : std::false_type { }; template <typename T> struct HasX<T, decltype((void) T::x, 0)> : std::true_type { };
Penyelesaian ini menggunakan ciri jenis decltype dan std::false_type untuk mengesan kehadiran x dalam kelas yang diberikan . Jika T mempunyai pembolehubah ahli x, HasX
Untuk menunjukkan penggunaan templat HasX:
struct A { int x; }; struct B { int y; }; int main() { std::cout << std::boolalpha << HasX<A>::value << std::endl; // true std::cout << std::boolalpha << HasX<B>::value << std::endl; // false return 0; }
Kod ini akan mencetak benar untuk HasX dan palsu untuk HasX, dengan betul menunjukkan kehadiran x dalam A dan ketiadaannya dalam B. Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengesan Kehadiran Pembolehubah Ahli Tertentu dalam Kelas C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!