Apabila bekerja dengan templat kelas, pengkhususan eksplisit fungsi ahli adalah keperluan biasa. Walau bagaimanapun, dalam kes di mana templat kelas itu sendiri menjadi templat, ralat mungkin timbul disebabkan pendekatan yang salah.
Pertimbangkan senario berikut:
template <class C> class X { public: template <class T> void get_as(); }; template <class C> void X<C>::get_as<double>() { }
Kod ini cuba mengkhususkan ahli secara eksplisit fungsi templat kelas X untuk jenis berganda. Walau bagaimanapun, apabila X sendiri dijadikan templat, pengkompil melaporkan ralat:
error: template-id 'get_as<double>' in declaration of primary template error: prototype for 'void X<C>::get_as()' does not match any in class 'X<C>'
Penyelesaiannya ialah dengan mengkhususkan templat kelas sekeliling secara eksplisit juga. Ini boleh dilakukan dengan menambahkan hujah templat kosong pada definisi ahli khusus:
template <> template <> void X<int>::get_as<double>() { }
Ini akan mengkhususkan fungsi ahli hanya untuk X
Sebagai alternatif, anda boleh menggunakan terlebih beban untuk mencapai tingkah laku yang diingini:
template <class C> class X { template<typename T> struct type { }; public: template <class T> void get_as() { get_as(type<T>()); } private: template<typename T> void get_as(type<T>) { } void get_as(type<double>) { } };
Pendekatan ini bergantung pada pengkhususan templat untuk memilih yang sesuai get_as() terlebih beban, memastikan bahawa pengkhususan jenis berganda digunakan seperti yang dimaksudkan.
Atas ialah kandungan terperinci Bagaimana untuk Mengkhususkan Fungsi Ahli Secara Eksplisit dalam Kelas Templat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!