Meneroka Kepelbagaian SFINAE
SFINAE, akronim untuk "kegagalan penggantian bukan ralat," memperkasakan pembangun dalam bidang templat pengaturcaraan meta. Ia membenarkan semakan bersyarat yang canggih semasa instantiasi templat.
Satu aplikasi SFINAE yang menarik adalah untuk mengesahkan keadaan boolean. Contohnya:
<code class="C++">template<int I> void div(char(*)[I % 2 == 0] = 0) { // Triggered when I is even } template<int I> void div(char(*)[I % 2 == 1] = 0) { // Triggered when I is odd }</code>
Kod ini menggunakan SFINAE untuk membezakan kesamaan I.
SFINAE seterusnya membolehkan pengesahan panjang senarai pemula yang dibina menggunakan operator koma. Pertimbangkan contoh berikut:
<code class="C++">template<int N> struct Vector { template<int M> Vector(MyInitList<M> const& i, char(*)[M <= N] = 0) { // ... } }</code>
Di sini, senarai pemula diterima hanya jika M kurang daripada atau sama dengan N, memastikan panjang senarai yang dibenarkan. Sintaks char(*)[C] menandakan penuding kepada tatasusunan aksara dengan saiz C. Jika C menilai kepada palsu (0 dalam kes ini), jenis char(*)[0] yang tidak sah dihasilkan. SFINAE dengan mudah mengabaikan templat dalam senario sedemikian.
Perwakilan alternatif menggunakan boost::enable_if ialah:
<code class="C++">template<int N> struct Vector { template<int M> Vector(MyInitList<M> const& i, typename enable_if_c<M <= N>::type* = 0) { // ... } }</code>
Dalam aplikasi praktikal, keupayaan semakan bersyarat yang disediakan oleh SFINAE terbukti tidak ternilai. Ia menawarkan pembangun alat serba boleh untuk menguatkuasakan kekangan dan menyesuaikan tingkah laku templat berdasarkan syarat tertentu.
Atas ialah kandungan terperinci Bagaimanakah SFINAE Mendayakan Pemeriksaan Bersyarat dalam Pemrograman Meta Templat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!