c++乘法溢出会怎样
展开全部
溢出的部分会被截掉。理论上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位丢失。
比如说有一段程序:
short a = 0xAAAA;
short b = 0xBBBB;
int d = a * b; // 这个正常,d=0x7d26 d82e
short c = a * b; // 这个会溢出,导致截断c=0xd82e, 只有正常值的低16位,高16位丢失。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |