我是 Golang 的新手package mainimport "fmt"func main() { var u uint8 = 255 var m uint16 = 255 fmt.Println(u, u-1, u*(u-1)) fmt.Println(m, m+1, m*m)}輸出./g2255 254 2255 256 65025我知道我在第一種情況下溢出了。但是為什么我得到的結(jié)果是2呢?
1 回答

犯罪嫌疑人X
TA貢獻(xiàn)2080條經(jīng)驗(yàn) 獲得超4個(gè)贊
你已經(jīng)暗示過溢出,事實(shí)上這正是這里發(fā)生的事情。您已經(jīng)知道 和u是什么u-1(分別是 255 和 254),所以讓我們將它們相乘。這給了我們 64770,或二進(jìn)制:
64770 = 1111 1101 0000 0010
這個(gè)結(jié)果是 16 位寬,但我們將它存儲(chǔ)在uint8只有 8 位寬的 a 中。因此它被截?cái)酁?8 個(gè)最低有效位。從數(shù)學(xué)上講,這相當(dāng)于執(zhí)行64770 mod 2^8或64770 mod 256。在編程上,它等同于執(zhí)行64770 & (1 << 7)or 64770 & 256:
64770 = 1111 1101 0000 0010
256 = 1111 1111
64770 & 256 = 0000 0000 0000 0010 = 2
無論您選擇如何想象這個(gè)操作,結(jié)果都是 2。
- 1 回答
- 0 關(guān)注
- 148 瀏覽
添加回答
舉報(bào)
0/150
提交
取消