c++乘法溢出会怎样

2025-06-29 06:20:56
推荐回答(1个)
回答1:

溢出的部分会被截掉。理论上16位的数乘以16位的数应该用一个32位的数来存储,如果只用16位的来存储,则乘积的高位溢出部分会被截掉。(一般int是32位的,所以要用64位的值比如 long long类型的来存储乘积)

比如说有一段程序:
short a = 0xAAAA;
short b = 0xBBBB;
int d = a * b; // 这个正常,d=0x7d26 d82e
short c = a * b; // 这个会溢出,导致截断c=0xd82e, 只有正常值的低16位,高16位丢失。