C语言整数溢出

什么是整数溢出?

        计算机语言中整数类型都有一个取值范围,两个整数进行运算时,若其结果大于最大值(上溢)或者小于最小值(下溢)就是 溢出

假如最大值为a,在最大值和最小值之间如果发生以下计算:

INT_MAX + 1 或 INT_MIN - 1

此时就会发生溢出,其中 INT_MAX + 1会发生上溢,INT_MIN - 1会发生下溢。

程序实例

// 整数溢出例子
#include 

int main(void)
{
 short i = 32767;
 unsigned short j = 65535;
 unsigned short k = 0;
 // 上溢例子
 printf("%hd %hd %hd\n", i, i+1, i+2);  
 // 上溢例子
 printf("%hu %hu %hu\n", j, j+1, j+2); 
 // 下溢例子
 printf("%hu %hu %hu\n", k, k-1, k-2); 
 return 0;
}

在32bit环境中编译,程序运行结果为:
C语言整数溢出_第1张图片
        在32bit环境中,short(占两个字节)的范围为-32768~32767, unsigned short的范围为0~65535

        所以short类型的i=32767加1、加2时会产生上溢。unsigned short类型的j=65535加1、加2时会产生上溢。unsigned short类型的k=0减1、减2时会产生下溢。

你可能感兴趣的:(零碎小知识,c语言,c++,开发语言)