Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimanakah Python menukar nilai tuple tanpa menggunakan pembolehubah sementara?

Bagaimanakah Python menukar nilai tuple tanpa menggunakan pembolehubah sementara?

Mary-Kate Olsen
Lepaskan: 2024-11-28 09:07:10
asal
321 orang telah melayarinya

How does Python swap tuple values without using a temporary variable?

Bertukar Nilai dalam Tuples: A Peek Inside

Dalam Python, menukar nilai dua pembolehubah menggunakan tugasan tuple seperti (a, b) = (b, a) mungkin kelihatan seperti helah mudah, tetapi bagaimanakah ia berfungsi secara dalaman tanpa pembolehubah sementara?

Timbunan Manipulasi

Python menilai ungkapan sebelah kanan tugasan secara berasingan daripada sebelah kiri. Setelah bahagian sebelah kanan dikira, hasilnya disimpan pada timbunan. Kemudian, nama sebelah kiri diberikan menggunakan opcode yang beroperasi terus pada tindanan.

Untuk tugasan tuple dengan dua atau tiga item, Python menggunakan tindanan terus menggunakan ROT_TWO atau ROT_THREE opcode untuk menukar elemen. Contohnya:

def foo(a, b):
    a, b = b, a
Salin selepas log masuk

Menyahpasang fungsi ini menggunakan dis.dis(foo) mendedahkan perkara berikut:

  2           0 LOAD_FAST                1 (b)
              3 LOAD_FAST                0 (a)
              6 ROT_TWO             
              7 STORE_FAST               0 (a)
             10 STORE_FAST               1 (b)
             13 LOAD_CONST               0 (None)
             16 RETURN_VALUE        
Salin selepas log masuk

Di sini, ROT_TWO menukar dua nilai teratas pada tindanan, dengan berkesan membalikkan pesanan a dan b.

Pembinaan Tuple dan Membongkar

Untuk tugasan yang melibatkan lebih daripada tiga elemen, Python membina tuple perantaraan pada timbunan. Pertimbangkan contoh ini:

def bar(a, b, c, d):
    d, c, b, a = a, b, c, d
Salin selepas log masuk

Pembubarannya menunjukkan:

  2           0 LOAD_FAST                0 (a)
              3 LOAD_FAST                1 (b)
              6 LOAD_FAST                2 (c)
              9 LOAD_FAST                3 (d)
             12 BUILD_TUPLE              4
             15 UNPACK_SEQUENCE          4
             18 STORE_FAST               3 (d)
             21 STORE_FAST               2 (c)
             24 STORE_FAST               1 (b)
             27 STORE_FAST               0 (a)
             30 LOAD_CONST               0 (None)
             33 RETURN_VALUE        
Salin selepas log masuk

BUILD_TUPLE membina tuple daripada nilai pada tindanan dalam susunan terbalik. Kemudian, UNPACK_SEQUENCE memunculkan tuple dan meletakkan elemennya kembali ke tindanan untuk tugasan ke pembolehubah sebelah kiri.

Pengoptimuman

Sementara UNPACK_SEQUENCE kelihatan berlebihan untuk tugasan dua atau tiga item, a langkah pengoptimuman kemudian menggantikan kombo BUILD_TUPLE/UNPACK_SEQUENCE dengan lebih banyak opcode ROT_TWO atau ROT_THREE yang cekap, memastikan mekanisme pertukaran adalah diperkemas yang mungkin.

Atas ialah kandungan terperinci Bagaimanakah Python menukar nilai tuple tanpa menggunakan pembolehubah sementara?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan