Dalam pengaturcaraan generik C++, dua kaedah disediakan untuk mengendalikan maklumat jenis masa jalan (RTTI): Pengendali dynamic_cast digunakan untuk menukar penunjuk kelas asas atau rujukan kepada penuding atau rujukan kelas terbitan. Operator typeid mengembalikan maklumat jenis objek, dan nama jenis boleh diperolehi melalui fungsi ahli name()nya. RTTI, walaupun mudah, dikenakan overhed tambahan dan oleh itu hanya disyorkan apabila diperlukan, dengan mengambil kira isu keserasian binari yang mungkin disebabkannya.
Mengendalikan maklumat jenis masa jalan (RTTI) dalam pengaturcaraan generik C++
Dalam pengaturcaraan generik C++, kita selalunya perlu mendapatkan maklumat jenis objek atau pembolehubah rujukan semasa masa jalan. C++ menyediakan mekanisme maklumat jenis masa jalan (RTTI) untuk tujuan ini.
Menggunakan dynamic_cast
pengendalidynamic_cast
digunakan untuk menukar penunjuk kelas asas atau rujukan kepada penuding atau rujukan kelas terbitan. Jika penukaran berjaya, ia mengembalikan penunjuk atau rujukan kepada kelas terbitan jika tidak, nullptr
dikembalikan. dynamic_cast
运算符用于将一个基类指针或引用转换为派生类指针或引用。如果转换成功,它返回派生类的指针或引用;否则,返回 nullptr
。
class Base { }; class Derived : public Base { }; int main() { Base* base_ptr = new Derived(); // 检查 base_ptr 是否指向 Derived 对象 Derived* derived_ptr = dynamic_cast<Derived*>(base_ptr); if (derived_ptr != nullptr) { // 转换成功,base_ptr 指向 Derived 对象 } }
使用 typeid
typeid
运算符返回对象的类型信息,该类型信息是一个 std::type_info
对象。可以使用 name()
成员函数获取类型名称,可以使用 before()
和 after()
class Base { }; class Derived : public Base { }; int main() { Base obj; std::cout << typeid(obj).name() << std::endl; // 输出:Base // 检查 obj 是否属于 Derived 类型 if (typeid(obj).before(typeid(Derived))) { std::cout << "obj is not a Derived object" << std::endl; } }
Gunakan pengendali typeid
typeid
untuk mengembalikan maklumat jenis objek, iaitu objek std::type_info
. Nama jenis boleh diperoleh menggunakan fungsi ahli name()
dan jenis boleh dibandingkan menggunakan fungsi ahli before()
dan after()
. class Shape { public: virtual void draw() = 0; }; class Circle : public Shape { public: void draw() override { std::cout << "Drawing a circle" << std::endl; } }; class Rectangle : public Shape { public: void draw() override { std::cout << "Drawing a rectangle" << std::endl; } }; class Triangle : public Shape { public: void draw() override { std::cout << "Drawing a triangle" << std::endl; } }; int main() { std::vector<Shape*> shapes{new Circle, new Rectangle, new Triangle}; for (auto shape : shapes) { // 使用 RTTI 获取形状类型 std::cout << "Drawing a " << typeid(*shape).name() << std::endl; // 根据类型调用相应的方法 shape->draw(); } }
RTTI menanggung overhed tambahan, jadi disyorkan untuk menggunakannya hanya apabila diperlukan. RTTI boleh menyebabkan isu keserasian binari, jadi berhati-hati apabila menggunakan RTTI dalam perpustakaan.
Kes praktikal
Senario:
Terdapat satu set bentuk (seperti bulatan, segi empat tepat dan segi tiga) yang perlu melakukan operasi berbeza berdasarkan jenisnya. 🎜Kod: 🎜🎜Drawing a Circle Drawing a Rectangle Drawing a Triangle
Atas ialah kandungan terperinci Bagaimana untuk mengendalikan maklumat jenis runtime dalam pengaturcaraan generik C++?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!