Selesaikan kekaburan dalam warisan Apabila terdapat fungsi dengan nama yang sama, anda boleh menyelesaikan kekaburan dengan menggunakan kaedah berikut: gunakan penyelesai skop (::) untuk menentukan kelas yang dimiliki oleh fungsi tersebut. Gantikan fungsi kelas asas dalam kelas terbitan. Cipta penuding kelas asas kepada objek kelas terbitan dan kemudian gunakan penuding untuk memanggil fungsi kelas asas.
Apabila kelas asas dan kelas terbitan mempunyai fungsi dengan nama yang sama, kekaburan dalam pewarisan akan berlaku apabila kelas asas dan kelas terbitan mempunyai fungsi dengan nama yang sama, fungsi penyalahgunaan akan berlaku dalam soalan. Ini kerana pengkompil tidak dapat menentukan versi fungsi yang hendak dipanggil.
Terdapat beberapa cara untuk menyelesaikan kekaburan dalam warisan:
Menggunakan penyelesai skop : Gunakan penyelesai skop (::
) untuk menentukan kelas yang anda gunakan untuk memanggil fungsi tersebut.
class Base { public: void func() { std::cout << "Base::func()" << std::endl; } }; class Derived : public Base { public: void func() { std::cout << "Derived::func()" << std::endl; } void callBaseFunc() { Base::func(); // 使用作用域解析符调用基类函数 } };
Timpa fungsi kelas asas: Gantikan fungsi kelas asas dalam kelas terbitan.
class Base { public: virtual void func() { std::cout << "Base::func()" << std::endl; } }; class Derived : public Base { public: void func() override { std::cout << "Derived::func()" << std::endl; } };
Gunakan penunjuk kelas asas: Buat penunjuk kelas asas dan tuding ke objek kelas terbitan. Kemudian, gunakan penuding untuk memanggil fungsi kelas asas.
class Base { public: void func() { std::cout << "Base::func()" << std::endl; } }; class Derived : public Base { public: void func() { std::cout << "Derived::func()" << std::endl; } }; int main() { Base* basePtr = new Derived; basePtr->func(); // 调用基类函数 return 0; }
Pertimbangkan kod berikut:
class Animal { public: void speak() { std::cout << "Animal speaks" << std::endl; } }; class Dog : public Animal { public: void speak() { std::cout << "Dog barks" << std::endl; } }; class Cat : public Animal { public: void speak() { std::cout << "Cat meows" << std::endl; } }; int main() { Animal* animal = new Dog; // 创建指向 Dog 对象的 Animal 指针 animal->speak(); // 调用 Dog::speak() animal = new Cat; // 创建指向 Cat 对象的 Animal 指针 animal->speak(); // 调用 Cat::speak() return 0; }
Dalam contoh ini, menggunakan penunjuk kelas asas boleh menyelesaikan masalah kekaburan. Kita boleh mengakses fungsi tertentu dari kelas terbitan yang berbeza tanpa sebarang pengubahsuaian eksplisit kepada kod tersebut.
Memahami kekaburan dalam warisan dan mengetahui cara menyelesaikannya adalah penting untuk menulis kod C++ yang mantap dan boleh diselenggara. Dengan menggunakan teknik yang diberikan, anda boleh dengan mudah mengendalikan kekaburan dan memastikan fungsi yang betul dipanggil.
Atas ialah kandungan terperinci Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk menangani kekaburan dalam warisan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!