Senarai Pemula untuk Tatasusunan Ahli: A C 0x Puzzle
Dalam C 0x, pengenalan senarai pemula telah membuka kemungkinan baharu untuk memulakan data ahli. Walau bagaimanapun, salah tanggapan biasa boleh timbul apabila cuba menggunakannya dengan tatasusunan ahli const.
Pertimbangkan kod berikut:
<code class="cpp">struct Foo { int const data[2]; Foo(std::initializer_list<int const>& ini) : data(ini) {} }; int main() { Foo f = {1, 3}; }</code>
Bertentangan dengan jangkaan, kod ini akan gagal untuk disusun dengan ralat:
<code class="text">incompatible types in assignment of ‘std::initializer_list<const int>’ to ‘const int [2]’</code>
Isu ini berpunca daripada fakta bahawa data ahli tatasusunan adalah malar, manakala senarai pemula ini memegang nilai bukan tetap. Untuk menyelesaikan ketidakpadanan ini, pengkompil perlu melakukan penukaran const pada setiap nilai dalam senarai pemula. Walau bagaimanapun, ini tidak dibenarkan oleh spesifikasi bahasa.
Pembina Templat Variadik untuk Menyelamat
Daripada menggunakan pembina senarai pemula, pembina templat variadic boleh digunakan :
<code class="cpp">struct Foo { int x[2]; template <typename... T> Foo(T... ts) : x{ts...} {} }; int main() { Foo f1(1, 2); Foo f2{1, 2}; }</code>
Pembina ini mengambil bilangan parameter yang berubah-ubah, membenarkan untuk permulaan terus elemen tatasusunan. Perhatikan penggunaan brace-init-lists dalam fasa pemulaan {ts...}.
Kes Bukan Malar
Jika constness bukan satu keperluan, satu lagi pendekatan ialah melangkau pemulaan dalam pembina dan mengisi tatasusunan dalam badan fungsi:
<code class="cpp">struct Foo { int x[2]; Foo(std::initializer_list<int> il) { std::copy(il.begin(), il.end(), x); } };</code>
Kaedah ini kehilangan semakan had masa kompilasi tetapi masih merupakan pilihan yang berdaya maju dalam situasi tertentu.
Atas ialah kandungan terperinci Bolehkah senarai pemula memulakan tatasusunan ahli const dalam C 0x?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!