Apabila Pembina "Persendirian" dalam C Menjadi Umum
Dalam C , mengisytiharkan pembina lalai jenis sebagai peribadi biasanya mengehadkan kebolehcapaiannya. Walau bagaimanapun, dalam senario tertentu, sekatan ini mungkin dipintas secara tidak dijangka.
Pertimbangkan contoh berikut:
class C { C() = default; // Private default constructor }; int main() { C c; // Error: Constructor is private auto c2 = C(); // Error: Constructor is private }
Dalam kes ini, kedua-dua percubaan untuk mencipta contoh C gagal disebabkan oleh pembina persendirian . Anehnya, sekatan ini nampaknya ditarik balik apabila menggunakan pendakap kerinting untuk memulakan C secara langsung:
class C { C() = default; }; int main() { C c{}; // Success: Curly braces allow object initialization auto c2 = C{}; // Success: Initialization not affected by private constructor }
Menyingkap Trik
Tingkah laku pelik ini berpunca daripada pemulaan agregat C 14 peraturan. Seperti pada 8.4.2/5 [dcl.fct.def.default], pembina lalai tidak dianggap "disediakan pengguna" jika ia lalai secara eksplisit dalam pengisytiharan pertamanya. Memandangkan pembina lalai C menepati kriteria ini, ia tidak dianggap sebagai disediakan pengguna.
Oleh itu, C memenuhi takrifan agregat mengikut 8.5.1/1 [dcl.init.aggr]: ia tidak mempunyai pembina yang disediakan pengguna, ahli data bukan statik peribadi atau dilindungi, kelas asas atau fungsi maya.
Permulaan Agregat
Agregat ialah jenis khas dengan pemulaan yang dipermudahkan peraturan. Pendakap kerinting dalam konteks ini menandakan permulaan agregat, yang membolehkan penciptaan objek walaupun dengan pembina persendirian. Dalam kes kami, pengkompil menganggap {} sebagai senarai pemula, memintas sekatan pembina peribadi dan memulakan C sebagai agregat.
Atas ialah kandungan terperinci Mengapakah Menggunakan Pendakap Kerinting Membenarkan Permulaan Kelas dengan Pembina Lalai Persendirian dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!