先看一个例子,将两个32位的Int型数相乘,将结果赋给long型变量。
long a=111111 * 111111;
乍一看好像没毛病,但这是个坑,慎跳!相乘以后的值会溢出。
原因:
对于编译器来说,int和int相乘,结果也是先存在int中,跟被赋给long还是longlong数据类型的字段没有关系。
解决办法:
想要不溢出,就要把两个32位数强制转换成long类型,再相乘。
本文揭示了32位整数相乘可能导致的溢出问题,通过实例说明了当两个32位Int型数相乘并赋值给long型变量时,若不进行类型转换,结果可能超出Int范围导致溢出。文章提供了正确的解决方案,即通过将整数强制转换为long型后再进行乘法运算,以避免溢出。
先看一个例子,将两个32位的Int型数相乘,将结果赋给long型变量。
long a=111111 * 111111;
乍一看好像没毛病,但这是个坑,慎跳!相乘以后的值会溢出。
原因:
对于编译器来说,int和int相乘,结果也是先存在int中,跟被赋给long还是longlong数据类型的字段没有关系。
解决办法:
想要不溢出,就要把两个32位数强制转换成long类型,再相乘。
您可能感兴趣的与本文相关的镜像
Stable-Diffusion-3.5
Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率
4739

被折叠的 条评论
为什么被折叠?