Bagaimanakah Anda Boleh Melaksanakan Kamus Tidak Boleh Berubah dan Boleh Hash dalam Python?

Patricia Arquette
Lepaskan: 2024-10-31 09:48:02
asal
936 orang telah melayarinya

How Can You Implement Immutable, Hashable Dictionaries in Python?

Kamus Tidak Boleh Ubah dan Boleh Cincang dalam Python

Set dan tupel beku menyediakan rakan sejawat yang tidak boleh diubah dan boleh cincang kepada senarai dalam Python. Walau bagaimanapun, konsep yang sama untuk kamus adalah kurang. "Frozendict" akan memberikan representasi kamus yang tidak berubah dan boleh dicincang.

Pelaksanaan dan Penggunaan

Walaupun Python tidak menawarkan jenis kamus beku secara asli, ia mungkin untuk mencipta pelaksanaan tersuai menggunakan kelas pembalut:

<code class="python">class FrozenDict(collections.Mapping):
    # ... (code as provided in the reference answer)</code>
Salin selepas log masuk

Gelagat dan Perbandingan

Kelakuan FrozenDict berkelakuan serupa dengan kamus biasa, menyokong lelaran, akses item dan keahlian ujian. Walau bagaimanapun, ia tidak boleh ubah, bermakna apabila dibuat, ia tidak boleh diubah suai.

Walaupun ia tidak boleh diubah, kejadian FrozenDict boleh dibandingkan untuk kesaksamaan berdasarkan sifat boleh cincang mereka:

>>> x = FrozenDict(a=1, b=2)
>>> y = FrozenDict(a=1, b=2)
>>> x is y
False
>>> x == y
True
Salin selepas log masuk

Utiliti

FrozenDict amat berguna untuk caching dan memoisasi, apabila kunci tidak berubah dan boleh cincang diperlukan. Sebagai contoh, ia boleh digunakan untuk menyimpan versi cincang nilai kamus untuk perbandingan yang cekap:

>>> cache = {}
>>> def memoized_function(args):
>>>     key = FrozenDict(args)
>>>     if key in cache:
>>>         return cache[key]
>>>     else:
>>>         result = ...  # Computation here
>>>         cache[key] = result
>>>         return result
Salin selepas log masuk

PEP 603

Perlu diperhatikan bahawa PEP 603 mencadangkan jenis frozendict asli dalam Python, tetapi ia telah ditarik balik kerana kebimbangan tentang potensi kegunaannya. Namun begitu, pelaksanaan tersuai seperti FrozenDict menyediakan penyelesaian praktikal untuk situasi di mana kamus tidak berubah dan boleh cincang diperlukan.

Atas ialah kandungan terperinci Bagaimanakah Anda Boleh Melaksanakan Kamus Tidak Boleh Berubah dan Boleh Hash dalam Python?. 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