Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk mengendalikan maklumat jenis runtime dalam pengaturcaraan generik C++?

Bagaimana untuk mengendalikan maklumat jenis runtime dalam pengaturcaraan generik C++?

WBOY
WBOYasal
2024-06-04 20:36:00648semak imbas

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.

C++ 泛型编程中如何处理运行时类型信息?

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();
      }
    }
  • Nota tentang penggunaan RTTI

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
🎜Output: 🎜rrreee

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn