Memahami Pewarisan Templat dan Carian Nama Tidak Bergantung
Pertimbangkan coretan kod berikut:
<code class="cpp">// arrayListType.h template <class elemType> class arrayListType { protected: elemType *list; int length; }; // unorderedArrayListType.h template <class elemType> class unorderedArrayListType: public arrayListType<elemType> { }; // main1.cpp unorderedArrayListType<int> intList(25);</code>
Menyusun ini kod menghasilkan ralat: "panjang tidak diisytiharkan dalam skop ini," menunjukkan bahawa pembolehubah yang dilindungi bagi kelas induk, arrayListType, tidak kelihatan dalam kelas yang diwarisi, unorderedArrayListType.
Ini disebabkan oleh konsep dikenali sebagai carian nama tidak bergantung, yang mentakrifkan cara pengkompil menyelesaikan rujukan kepada nama tidak bergantung dalam templat. Nama tidak bergantung ialah nama yang tidak bergantung pada parameter templat, seperti pembolehubah ahli atau nama fungsi ahli.
Dalam kes ini, pembolehubah yang dilindungi dalam arrayListType ialah nama tidak bergantung dan ia tidak secara eksplisit ditakrifkan dalam definisi kelas unorderedArrayListType. Pengkompil tidak dapat menentukan bahawa nama ini wujud dalam kelas yang diwarisi dan oleh itu melaporkan ralat.
Membetulkan Ralat
Terdapat dua pendekatan biasa untuk menangani ralat ini:
Menggunakan ini-> Awalan:
Membubuh awalan nama bukan bergantung dengan ini-> secara jelas menunjukkan bahawa mereka merujuk kepada ahli yang diwarisi:
<code class="cpp">class unorderedArrayListType: public arrayListType<elemType> { public: void insertAt(int location, const elemType& insertItem) { this->length++; this->list[location] = insertItem; } };</code>
Menggunakan Pengisytiharan:
Menggunakan pengisytiharan secara eksplisit mengisytiharkan nama bukan bergantung dalam kelas yang diwarisi:
<code class="cpp">class unorderedArrayListType: public arrayListType<elemType> { public: using arrayListType<elemType>::list; using arrayListType<elemType>::length; void insertAt(int location, const elemType& insertItem) { length++; list[location] = insertItem; } };</code>
Kedua-dua kaedah berkomunikasi dengan berkesan kepada pengkompil bahawa nama tidak bergantung adalah kepunyaan kelas yang diwarisi dan membolehkan kompilasi diteruskan dengan jayanya.
Atas ialah kandungan terperinci Mengapakah Saya Tidak Boleh Mengakses Ahli Dilindungi Kelas Asas Saya dalam Kelas Terhasil Templat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!