Cara fmt.Printf Memformat Nombor Perduaan untuk Integer Ditandatangani
Dalam sistem komputer, integer yang ditandatangani biasanya diwakili menggunakan tatatanda pelengkap dua. Walau bagaimanapun, apabila menggunakan fmt.Printf untuk mencetak perwakilan binari integer yang ditandatangani, seseorang mungkin menemui hasil yang tidak dijangka.
Sebagai contoh, pertimbangkan kod berikut:
var i int8 = -5 fmt.Printf("%b", i)
Kod ini menghasilkan keluaran "-101", yang bukan representasi pelengkap dua jangkaan "-5". Percanggahan ini berpunca daripada pengendalian dalaman pemformatan binari oleh fmt.Printf.
Isunya terletak pada penukaran integer bertanda negatif kepada positif dalam fmt.Printf. Fungsi ini membalikkan tanda integer input, menjadikannya integer tidak bertanda dengan berkesan. Akibatnya, fmt.Printf menambahkan tanda '-' sebelum perwakilan binari tidak ditandatangani ditukar.
Untuk mengesahkan tingkah laku ini, kita boleh menukar integer yang ditandatangani kepada integer tidak ditandatangani dan mencetaknya:
var u uint8 = uint(i) fmt.Printf("%b", u)
Ini menghasilkan output "11111011", yang sejajar dengan perwakilan pelengkap kedua-dua -5. Oleh itu, walaupun nilai asas memang diwakili dalam pelengkap dua secara dalaman, fungsi fmt.Printf mengubah format semasa output.
Atas ialah kandungan terperinci Mengapakah fmt.Printf memaparkan perwakilan binari yang berbeza untuk integer yang ditandatangani dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!