Rumah >pembangunan bahagian belakang >C++ >Cara Memulakan Tatasusunan Ahli dalam C 0x Constructors: Mengapa Menggunakan `std::initializer_list` Gagal dan Bagaimana untuk Menyelesaikannya?
Senarai Pemula dan Tatasusunan Ahli dalam C 0x
Pada peringkat awal pembelajaran C 0x, adalah perkara biasa untuk menghadapi ralat sintaks semasa bereksperimen dengan ciri baharu. Khususnya, isu ini timbul apabila cuba untuk memulakan tatasusunan ahli dalam pembina menggunakan senarai pemula.
Pertimbangkan kod berikut:
<code class="cpp">struct Foo { int const data[2]; Foo(std::initializer_list<int const>& ini) : data(ini) {} }; Foo f = {1,3};</code>
Setelah penyusunan, kod ini mencetuskan ralat berikut:
incompatible types in assignment of ‘std::initializer_list<const int>&’ to ‘const int [2]’
Untuk menyelesaikan ralat ini, pendekatan yang disyorkan dalam jawapan yang disediakan melibatkan penggunaan pembina templat variadic bukannya pembina senarai pemula. Menggunakan kaedah ini memastikan keserasian jenis dan membolehkan pemulaan fleksibel tatasusunan ahli:
<code class="cpp">struct foo { int x[2]; template <typename... T> foo(T... ts) : x{ts...} {} // curly braces syntax for initializer list }; int main() { foo f1(1, 2); // compiles successfully foo f2{1, 2}; // also compiles foo f3(42); // x[1] is zero-initialized }</code>
Sebagai alternatif, jika mengekalkan keteguhan tidak penting, anda boleh memilih kaedah yang melibatkan mengisi tatasusunan dalam badan pembina:
<code class="cpp">struct foo { int x[2]; foo(std::initializer_list<int> il) { std::copy(il.begin(), il.end(), x); } };</code>
Walaupun pendekatan ini mungkin berdaya maju, ia mengorbankan semakan had masa kompilasi yang disediakan oleh pembina templat variadic.
Atas ialah kandungan terperinci Cara Memulakan Tatasusunan Ahli dalam C 0x Constructors: Mengapa Menggunakan `std::initializer_list` Gagal dan Bagaimana untuk Menyelesaikannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!