Rumah > Artikel > pembangunan bahagian belakang > Mengapa fmt.Printf Output \"-101\" untuk Integer Bertandatangan Diwakili dalam Pelengkap Dua?
Two's Complement and fmt.Printf Binary Output
Apabila komputer menggunakan Two's complement untuk mewakili integer yang ditandatangani, nilai seperti -5 disimpan sebagai corak bit "1111 1011." Walau bagaimanapun, apabila cuba mencetak perwakilan binari ini menggunakan fmt.Printf seperti ini:
<code class="go">var i int8 = -5 fmt.Printf("%b", i)</code>
Output secara tidak dijangka menunjukkan "-101." Mengapa ini berlaku, dan adakah pelengkap Two digunakan secara dalaman?
Isu dengan Pemformatan Binari
Percanggahan terletak pada cara fmt.Printf mengendalikan pemformatan binari. Apabila memformat integer bertanda negatif, ia menukarnya kepada nilai positif dan kemudian menambahkan tanda '-' sebelum rentetan yang diformatkan.
Melihat ke dalam kod sumber fmt.Printf, kami mendapati bahawa fmt.integer menukar integer yang ditandatangani kepada nilai positif sebelum memformatkannya:
<code class="go"> negative := signedness == signed && a < 0 if negative { a = -a }</code>
Output Tidak Ditandatangani lwn. Ditandatangani
Untuk menunjukkan ini, pertimbangkan kod ini:
<code class="go">var u uint8 = uint(i) fmt.Printf("%b", u)</code>
Di sini, kami menukar i kepada integer tidak bertanda sebelum mencetaknya. Kali ini, output menunjukkan "11111011" dengan betul, yang merupakan pelengkap Dua bagi -5.
Kesimpulan
Untuk mencetak perwakilan binari integer yang ditandatangani dengan betul menggunakan fmt.Printf, kita harus terlebih dahulu menukarnya kepada integer positif menggunakan jenis tidak bertanda. Ini memastikan fmt.Printf tidak menukar nilai secara automatik kepada nilai negatif dan menambah tanda '-'.
Atas ialah kandungan terperinci Mengapa fmt.Printf Output \"-101\" untuk Integer Bertandatangan Diwakili dalam Pelengkap Dua?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!