Apakah fungsi bersembunyi di C?
Fungsi bersembunyi di C berlaku apabila kelas yang diperolehi mentakrifkan fungsi dengan nama yang sama sebagai fungsi kelas asas, menjadikan versi asas tidak dapat diakses melalui kelas yang diperolehi. Ini berlaku apabila fungsi asas bukan maya atau tandatangan tidak sesuai untuk mengatasi, dan tidak menggunakan perisytiharan digunakan. 1. Ia menghalang semua kelebihan fungsi asas. 2. Nama carian berhenti di kelas yang diperolehi. 3. Betulkan dengan menggunakan asas :: func, panggilan eksplisit, atau penamaan semula. 4. Berguna apabila sengaja menyekat akses tetapi sering tidak diingini dan harus diuruskan dengan teliti.
Fungsi bersembunyi di C adalah apabila fungsi dalam kelas yang diperoleh menghalang versi kelas asas fungsi yang sama dari yang boleh diakses melalui kelas yang diperolehi. Ini biasanya berlaku apabila anda mempunyai fungsi dengan nama yang sama (tetapi mungkin parameter yang berbeza atau jenis pulangan) di kedua -dua kelas dan kelas yang diperolehi.

Adalah penting untuk diperhatikan bahawa tingkah laku ini berbeza daripada fungsi yang mengatasi, yang hanya terpakai kepada fungsi maya dan mengekalkan hubungan antara versi asas dan yang diperolehi. Fungsi bersembunyi sepenuhnya menyembunyikan fungsi kelas asas apabila diakses melalui kelas yang diperolehi.

Bagaimana fungsi bersembunyi berlaku?
Fungsi bersembunyi berlaku di C di bawah syarat -syarat ini:
- Anda menentukan fungsi dalam kelas yang diperoleh dengan nama yang sama seperti fungsi dalam kelas asas.
- Fungsi dalam kelas asas tidak diisytiharkan maya , atau walaupun ia, tetapi tandatangan tidak sepadan dengan tepat untuk mengatasi.
- Kelas yang diperolehi tidak menggunakan secara eksplisit
using BaseClass::functionName;
Untuk membawa versi asas ke dalam skop.
Contohnya:

asas kelas { awam: void show () {cout << "Base Show"; } }; kelas yang diperolehi: asas awam { awam: void show (int x) {cout << "pertunjukan yang diperoleh dengan int"; } };
Sekarang, jika anda cuba menelefon show()
tanpa hujah pada objek Derived
, ia tidak akan menemui versi asas - ia tersembunyi.
Mengapa ia berlaku?
C Menggunakan peraturan yang dipanggil Nama Lookup : Apabila anda memanggil fungsi seperti obj.show()
, pengkompil mula melihat kelas obj
dan berhenti sebaik sahaja ia mendapati sebarang fungsi bernama show
. Jika Derived
mempunyai show
, ia tidak mengganggu pemeriksaan Base
.
Ini bermakna walaupun senarai parameter berbeza, sebaik sahaja anda mengisytiharkan fungsi dengan nama yang sama dalam kelas yang diperolehi, semua beban kelas asas tersembunyi.
Cara memperbaikinya atau mengelakkannya
Jika anda ingin menyimpan akses kepada kedua -dua versi fungsi, terdapat beberapa pilihan:
Gunakan Pengisytiharan
using
di kelas yang diperolehi:kelas yang diperolehi: asas awam { awam: menggunakan asas :: tunjukkan; // membawa pertunjukan asas ke dalam skop void show (int x) {cout << "pertunjukan yang diperoleh dengan int"; } };
Sekarang panggil
obj.show()
akan berfungsi semula, danobj.show(5)
akan memanggil versi yang diperolehi.Sebagai alternatif, hubungi fungsi kelas asas secara eksplisit:
Diperoleh d; d.base :: show (); // Panggilan Base's Show
Atau menamakan semula salah satu fungsi untuk mengelakkan konflik jika bersembunyi adalah tidak disengajakan.
- Anda merancang kelas yang diperolehi dan sengaja ingin mengeluarkan akses kepada fungsi yang diwarisi tertentu.
- Anda menggantikan fungsi sepenuhnya dan tidak mahu versi lama digunakan secara tidak sengaja.
Bilakah ia berguna?
Fungsi bersembunyi tidak selalu menjadi pepijat - kadang -kadang ia disengajakan. Contohnya:
Tetapi dalam kebanyakan kes, terutama ketika bekerja dengan hierarki warisan dan mengharapkan tingkah laku polimorfik, lebih baik menggunakan fungsi virtual
dan mengatasi yang tepat dan bukannya bergantung pada fungsi bersembunyi.
Oleh itu, fungsi bersembunyi pada dasarnya adalah kesan sampingan bagaimana resolusi nama berfungsi dalam c. Ia boleh melakukan anda jika anda tidak sedar, tetapi dengan using
pengisytiharan atau penamaan berhati -hati, anda boleh mengurusnya.
Atas ialah kandungan terperinci Apakah fungsi bersembunyi di C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Direktori apa yang ringkas (membuktikan) yang mencipta ringkas (membuktikan)? Modal teroka mana yang menyokong ringkas (membuktikan)? Betapa ringkasnya (membuktikan) berfungsi SP1ZKVM dan penguasaan rangkaian Opsuccon Teknologi Pengesahan rantaian rantaian membuktikan token token token token peruntukan token utiliti yang berpotensi pemegang token membuktikan ramalan harga token membuktikan aktiviti perdagangan pra-pasaran pra-pasaran ramalan masyarakat membuktikan harga token mengapa memilih yang ringkas? Succ

Jika ia meleleh apabila memadam elemen, anda mesti mengelakkan menggunakan Iterator yang gagal. ① Cara yang betul adalah menggunakannya = vec.erase (IT), dan gunakan iterator yang sah yang dikembalikan dengan memadam untuk terus melintasi; ② Idiom yang disyorkan untuk penghapusan batch: vec.erase (std :: rove_if (vec.begin (), vec.end (), syarat), vec.end ()), yang selamat dan cekap; ③ Anda boleh menggunakan iterator terbalik untuk memadam dari belakang ke depan, logiknya jelas, tetapi anda perlu memberi perhatian kepada arah keadaan. Kesimpulan: Sentiasa mengemas kini iterator dengan nilai pulangan memadam, melarang operasi pada Iterator yang gagal, jika tidak, tingkah laku yang tidak ditentukan akan dihasilkan.

Direktori Apa yang ringkas (membuktikan) Modal teroka yang menyokong ringkas (membuktikan)? Betapa ringkasnya (membuktikan) Prinsip Kerja SP1ZKVM dan Rangkaian Prover Teknologi Opsuccon Teknologi Pengesahan Cross-Chain Membuktikan Token Ekonomi Token Butiran 2025, 2026, 2027-2030 Ramalan Ramalan Ramalan (membuktikan)

Theautokeywordinc deducesthetypeofavariableFromitsinitializer, MakingCodeCleanerAndmoremaintainable.1.itreduceRosities, terutamanyaWithcomplextypesikeiterators.2.itenhancesmaintabilitybyautomaticallyAdAdAdAdAttottoTypeChanges.3.Isisnessaryaryaryypechanges

Tagdispatching menggunakan tag jenis untuk memilih kelebihan fungsi optimum semasa tempoh penyusunan untuk mencapai polimorfisme yang cekap. 1. Gunakan std :: iterator_traits untuk mendapatkan tag kategori iterator; 2. Tentukan pelbagai fungsi kelebihan DO_Advance, dan proses random_access_iterator_tag, bidrectional_iterator_tag dan input_iterator_tag masing -masing; 3. Fungsi utama My_Advance memanggil versi yang sepadan berdasarkan jenis tag yang diperolehi untuk memastikan tidak ada overhead runtime semasa keputusan masa kompilasi; 4. Teknologi ini diterima pakai oleh perpustakaan standard seperti STD :: Advance, dan menyokong penyesuaian lanjutan.

Apabila membuka perisian atau permainan, segera tiba -tiba muncul bahawa "aplikasi tidak boleh bermula secara normal (0xc0000906)" muncul, dan banyak pengguna akan dikelirukan dan tidak tahu di mana hendak bermula. Malah, kebanyakan kesilapan ini disebabkan oleh rasuah fail sistem atau perpustakaan runtime yang hilang. Jangan tergesa -gesa untuk memasang semula sistem. Artikel ini memberikan anda beberapa penyelesaian yang mudah dan berkesan untuk membantu anda memulihkan program dengan cepat. 1. Apakah ralat 0xc0000906? Kod Ralat 0xC0000906 adalah pengecualian permulaan yang biasa dalam sistem Windows, yang biasanya bermaksud bahawa program tidak dapat memuatkan komponen sistem yang diperlukan atau persekitaran yang berjalan ketika berjalan. Masalah ini sering berlaku apabila menjalankan perisian atau permainan besar. Sebab utama mungkin termasuk: Perpustakaan Runtime yang diperlukan tidak dipasang atau rosak. Pakej pemasangan perisian tidak berkesudahan

Gunakan kaedah Seekg dan Tellg std :: ifstream untuk mendapatkan saiz fail di seluruh platform. Dengan membuka fail binari dan meletakkannya hingga akhir, gunakan Tellg () untuk mengembalikan bilangan bait; 2. Adalah disyorkan untuk menggunakan std :: filesystem :: file_size untuk c 17 dan ke atas. Kod ini ringkas dan kesilapan dikendalikan melalui pengecualian. Piawaian C 17 mesti diaktifkan; 3. Pada sistem POSIX, fungsi stat () boleh digunakan untuk mendapatkan saiz fail dengan cekap, yang sesuai untuk senario sensitif prestasi. Kaedah yang sesuai harus dipilih berdasarkan pengkompil dan platform, dan sistem fail std :: harus digunakan terlebih dahulu (jika ada), jika tidak, gunakan IFStream untuk memastikan keserasian, atau gunakan ST pada sistem Unix

Contoh C Linked ini melaksanakan Operasi Sisip, Traversal dan Padam. 1. Gunakan InsertBeginning untuk memasukkan nod di kepala; 2. Gunakan sisipan untuk memasukkan nod dalam ekor; 3. Gunakan DeletEnode untuk memadam nod dengan nilai dan mengembalikan hasil Boolean; 4. Gunakan kaedah paparan untuk melintasi dan mencetak senarai yang dipautkan; 5. Percuma semua memori nod dalam pemusnah untuk mengelakkan kebocoran; Output program akhir mengesahkan ketepatan operasi ini, menunjukkan sepenuhnya kaedah pengurusan asas struktur data dinamik.
