Mengapa (1 dalam [1,0] == Betul) Menilai kepada Salah, Walaupun (1 dalam [1,0]) == Betul Menjadi Benar?
Apabila menemui ungkapan (1 dalam [1,0] == Benar), seseorang mungkin menjangkakan ia akan menilai kepada Benar seperti dalam kes (1 dalam [1,0]). Walau bagaimanapun, ia secara mengejutkan menilai kepada Palsu. Untuk memahami tingkah laku ingin tahu ini, adalah penting untuk menyelidiki rantaian operator perbandingan Python.
Mekanisme rantaian operator Python menafsirkan ungkapan sebagai:
<code class="python">(1 in [1, 0]) and ([1, 0] == True)</code>
Ungkapan ini mempunyai operator logik yang melata, dengan " dan" pengendali diutamakan. Akibatnya, penilaian diteruskan seperti berikut:
Memandangkan pengendali "dan" menghendaki kedua-dua operan itu Betul untuk hasil Betul, dan salah satu daripada operan itu Salah, keseluruhan ungkapan bernilai Salah.
Tingkah laku rantaian ini juga terpakai kepada pengendali perbandingan berantai yang lain, seperti:
Memahami mekanisme rantaian operator ini adalah penting untuk mentafsir dan mengubah suai ungkapan dengan betul yang melibatkan operator perbandingan berlatarkan dalam Python.
Atas ialah kandungan terperinci Mengapakah `(1 dalam [1, 0] == Benar)` Menilai kepada Salah Manakala `(1 dalam [1, 0]) == Benar` Menilai kepada Benar?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!