Memisahkan Kelas C Templat kepada Fail .hpp/.cpp
Masalah:
Menyusun pemisahan kelas templat C antara fail .hpp dan .cpp menghasilkan ralat rujukan yang tidak ditentukan untuk templat ahli fungsi.
Kod:
stack.hpp:
template <typename Type> class stack { public: stack(); ~stack(); };
stack.cpp:
#include <iostream> #include "stack.hpp" template <typename Type> stack<Type>::stack() { std::cerr << "Hello, stack " << this << "!" << std::endl; } template <typename Type> stack<Type>::~stack() { std::cerr << "Goodbye, stack " << this << "." << std::endl; }
main.cpp:
#include "stack.hpp" int main() { stack<int> s; return 0; }
Jawapan:
Penjelasan:
Ia tidak layak untuk memisahkan pelaksanaan kelas templat kepada fail .cpp yang berasingan untuk penyusunan. Fail pengepala hanya dipraproses dan tidak mengandungi kod sebenar.
Proses Penyusunan:
Apabila menyusun, kod pengepala praproses digabungkan dengan fail .cpp. Walau bagaimanapun, untuk kelas templat, pengkompil memerlukan maklumat tentang jenis data templat untuk menjana reka letak memori dan definisi kaedah.
Isu Fail cpp berasingan:
Mengalih kaedah takrifan kepada fail cpp yang berasingan tanpa membuat contoh kelas templat dalam fail pengepala tidak akan menjana maklumat fail objek yang diperlukan. Oleh itu, pemaut tidak dapat mencari simbol, yang membawa kepada ralat rujukan yang tidak ditentukan.
Pendekatan Alternatif:
Untuk memisahkan antara muka daripada pelaksanaan, pertimbangkan untuk mengasingkan struktur data daripada algoritma. Kelas templat hendaklah mewakili struktur data sahaja. Algoritma boleh dilaksanakan dalam perpustakaan kelas bukan templat berasingan yang berinteraksi dengan atau menggunakan kelas templat. Pendekatan ini membolehkan penyembunyian butiran pelaksanaan yang berharga.
Atas ialah kandungan terperinci Mengapa Saya Mendapat Rujukan Tidak Ditakrifkan Apabila Memisahkan Pelaksanaan Kelas C Templat ke dalam Fail .hpp dan .cpp?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!