Dalam C , susunan penilaian untuk penyata tugasan tidak selalu intuitif. Pertimbangkan kod berikut:
<code class="cpp">map<int, int> mp; printf("%d ", mp.size()); mp[10]=mp.size(); printf("%d\n", mp[10]);</code>
Kod yang kelihatan mudah ini secara mengejutkan mengeluarkan "0 1", yang mungkin bukan seperti yang anda jangkakan.
Untuk memahami sebabnya, kita mesti menyelidiki spesifik perintah penilaian C. Penyataan tugasan, seperti yang ditentukan oleh [expr.ass](https://en.cppreference.com/w/cpp/language/operator_assignment) standard C, "semua kumpulan dari kanan ke kiri." Ini bermakna operan kanan dinilai sebelum operan kiri. Selain itu, piawaian C menyatakan bahawa dalam operasi tugasan, "tugasan disusun mengikut urutan selepas pengiraan nilai operan kanan dan kiri, dan sebelum pengiraan nilai ungkapan tugasan."
Dalam kod kami, operan kiri ialah mp[10], yang merupakan operasi penugasan itu sendiri. Operan yang betul ialah mp.size(), yang menilai kepada 0 kerana peta pada mulanya kosong. Jadi, kod secara berkesan memberikan mp[10] kepada 0. Walau bagaimanapun, operasi penugasan disusun sebelum pengiraan nilai mp[10]. Ini bermakna pertama sekali, nilai mp[10] diubah suai, mencipta entri baharu dalam peta dan menetapkannya kepada 0. Selepas itu barulah nilai mp[10] dinilai, mendedahkan entri yang baru dibuat dengan nilai 1 .
Ini adalah contoh yang jelas bagi susunan penilaian yang kelihatan tidak dijangka dalam C . Untuk mengelakkan kejutan sedemikian, adalah penting untuk mengetahui spesifikasi standard dan untuk mempertimbangkan susunan operasi akan dilaksanakan. Dalam kes di mana tertib tidak penting atau potensi untuk tingkah laku yang tidak ditentukan wujud, kurungan eksplisit boleh digunakan untuk mengawal susunan penilaian.
Atas ialah kandungan terperinci Mengapakah `mp[10] = mp.size()` Output `1` dalam C Walaupun `mp` Kosong?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!