Rumah > pembangunan bahagian belakang > C++ > Bagaimanakah Kami Boleh Menangani Ralat Masa Penyusun Apabila Menggunakan CRTP dan Typedef dalam Kelas Terhasil C?

Bagaimanakah Kami Boleh Menangani Ralat Masa Penyusun Apabila Menggunakan CRTP dan Typedef dalam Kelas Terhasil C?

Linda Hamilton
Lepaskan: 2024-12-06 17:53:12
asal
873 orang telah melayarinya

How Can We Address Compile-Time Errors When Using CRTP and Typedef in C   Derived Classes?

Penggunaan Polimorfisme Statik dan Typedef daripada Kelas Terbitan dalam C

Salah satu ciri hebat C , Corak Templat Berulang Secara Aneh (CRTP), membolehkan polimorfisme statik. Ini membolehkan fleksibiliti masa kompilasi dalam menentukan jenis objek yang dibuat berdasarkan hujah templat. Walau bagaimanapun, memanjangkan CRTP untuk membenarkan pengubahsuaian jenis pengembalian fungsi berdasarkan jenis terbitan menimbulkan cabaran.

Pertimbangkan kod berikut yang cuba menyamaratakan CRTP:

template <typename derived_t>
class base {
public:
    typedef typename derived_t::value_type value_type;
    value_type foo() {
        return static_cast<derived_t*>(this)->foo();
    }
};

template <typename T>
class derived : public base<derived<T>> {
public:
    typedef T value_type;
    value_type foo() {
        return T();
    }
};
Salin selepas log masuk

Kod ini gagal dihimpun dalam Microsoft Visual Studio 2010 disebabkan oleh ralat: 'value_type' bukan ahli 'derived'.

Isu ini berpunca daripada fakta bahawa terbitan tidak lengkap apabila digunakan sebagai hujah templat untuk asas dalam senarai kelas asasnya. Untuk menangani perkara ini, penyelesaian biasa ialah menggunakan templat kelas ciri.

Memperkenalkan templat ciri_asas:

template <typename derived_t> 
struct base_traits;
Salin selepas log masuk

Mentakrifkan semula kelas asas menggunakan ciri:

template <typename derived_t> 
struct base { 
    typedef typename base_traits<derived_t>::value_type value_type;
    value_type base_foo() {
        return base_traits<derived_t>::call_foo(static_cast<derived_t*>(this));
    }
};
Salin selepas log masuk

Dan mengkhususkan ciri_asas untuk diturunkan:

template <typename T> 
struct base_traits<derived<T> > {
    typedef T value_type;

    static value_type call_foo(derived<T>* x) { 
        return x->derived_foo(); 
    }
};
Salin selepas log masuk

Pendekatan ini membolehkan penggunaan kedua-dua jenis dan fungsi daripada kelas terbitan melalui ciri-ciri. Dengan mengkhususkan base_traits untuk setiap hujah templat, anda boleh menyediakan ahli yang diperlukan untuk setiap kelas terbitan.

Atas ialah kandungan terperinci Bagaimanakah Kami Boleh Menangani Ralat Masa Penyusun Apabila Menggunakan CRTP dan Typedef dalam Kelas Terhasil C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan