Mengubah suai Senarai Semasa Mengulang
Apabila bekerja dengan senarai dalam Python, adalah penting untuk memahami akibat mengubah suainya semasa menggelung. Pertimbangkan kod berikut:
l = range(100) for i in l: print(i) print(l.pop(0)) print(l.pop(0))
Tanpa diduga, kod ini menghasilkan output yang salah. Mengapakah ini berlaku?
Apabila menggelung senarai dalam Python, iterator mengingati kedudukan semasa dan menggunakannya untuk mengulangi elemen. Walau bagaimanapun, jika senarai itu diubah suai semasa lelaran, ingatan lelaran tidak dikemas kini. Akibatnya, gelung mungkin melangkau atau menduplikasi elemen.
Dalam contoh di atas, l.pop(0) mengalih keluar elemen pertama daripada senarai. Oleh itu gelung diteruskan ke elemen kedua, tetapi lelaran masih mengingati elemen pertama. Ini membawa kepada gelung mencetak elemen pertama dua kali.
Untuk mengelakkan isu ini, adalah penting untuk tidak mengubah suai senarai semasa berulang. Sebaliknya, anda boleh menggunakan pembolehubah sementara atau salinan senarai untuk pengubahsuaian.
Sebagai alternatif, anda boleh mempertimbangkan untuk menggunakan gelung sementara dengan pembolehubah indeks, seperti dalam contoh ini:
i = 0 while i < len(l): print(l[i]) i += 1
Kaedah ini memastikan gelung itu berulang dengan betul melalui senarai, walaupun elemen dialih keluar semasa proses.
Atas ialah kandungan terperinci Mengapa Mengubah Suai Senarai Semasa Lelaran dalam Python Membawa kepada Keputusan yang Tidak Dijangka?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!