Dalam coretan kod ini:
template<class T> class Foo { public: Foo() { a = 1; } protected: int a; }; template<class T> class Bar : public Foo<T> { public: Bar() { b = 4; }; int Perna(int u); protected: int b; }; template<class T> int Bar<T>::Perna(int u) { int c = Foo<T>::a * 4; // This works return (a + b) * u; // This doesn't }
versi pengkompil GNU C yang lebih baharu (mis., 3.4 .6 dan 4.3.2) melaporkan an ralat:
error: `a' was not declared in this scope
apabila mengakses pembolehubah dilindungi a kelas asas Foo dalam pengkhususan Bar.
Versi GCC yang lebih baharu mengikut piawaian C, yang menyatakan bahawa nama yang tidak layak dalam templat adalah tidak bergantung dan mesti diselesaikan semasa definisi templat. Memandangkan takrif kelas asas bergantung mungkin tidak diketahui pada masa ini, nama tidak layak tidak boleh diselesaikan.
Menghalang akses ahli waris yang tidak layak dalam kelas asas bergantung memastikan templat ditakrifkan dengan baik dan bebas daripada pengkhususannya. Ini memastikan bahawa semantik templat kekal konsisten untuk pengkhususan yang berbeza.
Untuk mengakses pembolehubah yang diwarisi dalam Bar, anda boleh menggunakan nama yang layak:
template<class T> int Bar<T>::Perna(int u) { int c = Foo<T>::a * 4; return (Foo<T>::a + b) * u; }
Sebagai alternatif, anda boleh menggunakan pengisytiharan menggunakan:
template<class T> int Bar<T>::Perna(int u) { using Foo<T>::a; int c = a * 4; return (a + b) * u; }
Sintaks ini memaklumkan pengkompil yang a dalam skop Bar merujuk kepada pembolehubah kelas asas Foo.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengakses Pembolehubah Dilindungi Diwarisi daripada Kelas Induk Templat dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!