C语言 | 什么是整数溢出?

本文深入探讨了整数溢出的概念,通过具体的C语言代码示例,展示了当整数运算结果超出数据类型所能表示的范围时,将如何触发上溢或下溢现象。文章还提供了检查整数数据类型范围的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1024G 嵌入式资源大放送!包括但不限于C/C++、单片机、Linux等。关注微信公众号【嵌入式大杂烩】,回复1024,即可免费获取!

什么是整数溢出?

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

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

a+1=0或0-1=a

此时就会发生溢出,其中a+1=0会发生上溢,0-1=a会发生下溢。

程序实例

// 整数溢出例子
#include <stdio.h>

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环境中编译,程序运行结果为:

在这里插入图片描述

在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时会产生下溢。

(ps:可以使用程序来查看整数数据类型的范围,具体可查看往期笔记:【C语言笔记】如何查看数据类型范围?

以上就是关于整数溢出的笔记分享,如有错误欢迎指出!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式大杂烩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值