Memahami Peta STL dengan Jenis Kunci Ditentukan Pengguna
Dalam C , peta STL menawarkan struktur data yang berkuasa untuk mengatur data berdasarkan kunci unik . Walau bagaimanapun, menggunakan peta dengan jenis yang ditakrifkan pengguna boleh membawa kepada ralat penyusunan.
Punca Punca: Operator Perbandingan Hilang
Mesej ralat menyerlahkan ketiadaan lebihan beban kurang- daripada operator (<) untuk kelas yang ditentukan pengguna, Class1. Secara lalai, std::map menjangkakan kuncinya setanding menggunakan operator<, yang diperlukan untuk peta melaksanakan carian dan pengisihan yang cekap.
Menyelesaikan dengan Pembanding Tersuai
Untuk menyelesaikan isu ini, anda boleh mencipta kelas pembanding tersuai yang mentakrifkan logik perbandingan untuk objek Kelas1. Contohnya:
struct Class1Compare { bool operator() (const Class1& lhs, const Class1& rhs) const { return lhs.id < rhs.id; } }; std::map<Class1, int, Class1Compare> c2int;</p> <p>Di sini, kelas Class1Compare menyediakan pelaksanaan untuk membandingkan objek Class1 berdasarkan nilai idnya.</p> <p><strong>Alternatif: Mengkhususkan std::less</strong></p> <p>Sebagai alternatif, anda boleh mengkhususkan templat std::less untuk Kelas1 objek:</p> <pre class="brush:php;toolbar:false">namespace std { template<> struct less<Class1> { bool operator() (const Class1& lhs, const Class1& rhs) const { return lhs.id < rhs.id; } }; }
Dengan mengkhususkan std::less, anda menyediakan logik perbandingan khusus untuk objek Kelas1 sambil meminimumkan kerumitan kod.
Atas ialah kandungan terperinci Bagaimana untuk Menggunakan Jenis Kunci Ditakrifkan Pengguna dengan Peta C STL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!