C语言为什么会发⽣数据溢出?如何避免数据溢出?

这篇具有很好参考价值的文章主要介绍了C语言为什么会发⽣数据溢出?如何避免数据溢出?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、问题

有以下程序:

#include <stdio.h>
int main()
{
    int i, sum; /*声明变量 */
    i = 2147483647; /*定义变量*/
    sum = i + 1; /*变量值加1*/
    printf("%d,%d", i, sum); /*输出结果*/
    return 0;
}

运⾏后 sum 的结果是什么?

二、解答

1、分析

        按正常的计算,sum 应该是2147483648,但是运⾏后 sum 的结果是-2147483648。这是什么原因呢?

        在C语⾔中可以使⽤各种类型的标识符,但是C语⾔标准⾥并没有规定这些类型的具体⻓度,要由各个C编译系统⾃⼰规定。⼀般以⼀个机器字存放⼀个 int 数据,早期的计算机字⻓⼀般为16 位,故以16 位存放⼀个整数,整数的范围在-32768~32767 之间,整数范围太⼩,在使⽤的时候就容易产⽣溢出现象。

        在这段代码中,变量i被初始化为2147483647,这是一个int类型的最大值。当执行i+1时,由于int类型的取值范围是-2147483648到2147483647,因此i+1会产生溢出,结果不是预期的2147483648,而是-2147483648。

        但现代的计算机⼀般都为32 位以上,以 32 位存放⼀个整数,范围可达±2.1×10^9,所以当前⼀般将 int 和 long 都定义为32 位。在写程序时,要了解所⽤系统对标识符长度的规定,以免出现上⾯的错误。

        如果真的产⽣“溢出”,运⾏时也不会报错,⽽是将结果从“头”开始计算,即是上⾯的运⾏结果-327682147483648,这与编程者的原意不同。由于系统不会给出“出错信息”,所以要靠程序员的细⼼和经验来进⾏排错。

说明:
    当前⼤多编译器多将 int 规定为32 位,所以⼀般不会出现“溢出”现象。

2、解决⽅法

将数据定义为⻓整型long 类型,在输出的时候使⽤“%ld”即可。

注意:
    long 型数据可以得到⼤范围的整数,但同时会降低运算速度。因此,除⾮不得已,否则不要随便
使⽤ long 型。

三、总结

        C语⾔数值数据类型都有⼀个取值范围。在进⾏数值运算的时候,有时会因数值超出了定义类型的取值范围⽽产⽣溢出的情况。所以在表⽰数据时,应根据需要选择适当的数据类型。文章来源地址https://www.toymoban.com/news/detail-809242.html

到了这里,关于C语言为什么会发⽣数据溢出?如何避免数据溢出?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 区块链的去中心化账本有和意义?为什么要哈希运算?如何保证数据不可篡改?

    1、中心化账本是什么? 在互联网的世界里,价值是用数字来呈现的。而数字文件是可以无限复制的,在互联网的世界数字具有易错、易改、易拷贝的特性,但是价值是不能复制的。为了解决这一难题发展为由一个中心化的机构(支付宝/微信支付/银联等)负责记账和记录账户余

    2023年04月23日
    浏览(46)
  • 为什么C语言运行效率高

    C语言是一种高效的编程语言,因为它具有多种优点,使其成为一种非常适合进行系统级编程的语言。在本文中,我将详细解释C语言之所以高效的原因,并且探讨一些C语言程序员可以采取的最佳实践。 C语言是一种低级别编程语言,它允许程序员直接访问内存。这意味着程序

    2023年04月24日
    浏览(33)
  • 为什么开源语言大模型很重要?

    在LLM领域,开源究竟意味着什么?假设开源社区拥有了真正的开源LLM,其权重、数据集、代码和基础设施都可公开获取,我们又将从中获得哪些重要收益? 本文作者为Vikram Sreekanti和Joseph E. Gonzalez,前者是Aqueduct的联合创始人及CEO,后者是加州大学伯克利分校的教授和Run LLM联

    2024年02月05日
    浏览(48)
  • Go 语言为什么很少使用数组?

    大家好,我是 frank,「Golang 语言开发栈」公众号作者。 01 介绍 在 Go 语言中,数组是一块连续的内存,数组不可以扩容,数组在作为参数传递时,属于值传递。 数组的长度和类型共同决定数组的类型,不同类型的数组之间不可以比较,否则在编译时会报错。 因为数组的一些

    2024年02月04日
    浏览(43)
  • 为什么建议同时学多门编程语言

    晨读一本名叫《4点起床》的书,书中有一段描述与最近学习编制语言时自己的感受完全一致。算是一个小经验,分享给大家。 书中有一章的标题为《同时学六国语言记起来比较快》,其中有两段描述如下: 为什么我推荐大家同时学不同的语言呢?实不相瞒,我这几年在学西

    2024年02月10日
    浏览(65)
  • 为什么指针被誉为 C 语言灵魂?

    是的,这一篇的文章主题是「指针与内存模型」 说到指针,就不可能脱离开内存,学会指针的人分为两种,一种是不了解内存模型,另外一种则是了解。 不了解的对指针的理解就停留在“指针就是变量的地址”这句话,会比较害怕使用指针,特别是各种高级操作。 而了解内

    2024年02月08日
    浏览(27)
  • 什么是栈,为什么函数式编程语言都离不开栈?

    ​ 栈是一种具有特殊访问方式的存储空间,它的特殊性在于, 最后进入这个空间的数据,最先出去 ,可以画图来描述一下这种操作方式。 假设有一个盒子和三本书,依次将三本书他们放入盒子中。 入栈模拟图 ​ 现在有一个问题,如果一次只能取一本,我们如何将书从盒子

    2024年02月06日
    浏览(54)
  • 为什么 C 语言没有被 C++ 取代?

    今日话题,为什么 C 语言没有被 C++ 取代?C语言之所以没有被C++完全取代,有几个主要原因。首先,C++的编译器实现相对复杂,这对于一些嵌入式平台来说是一个问题。许多嵌入式系统只支持C语言,因此C++在这些平台上无法使用。即使在支持C++的嵌入式平台上,也常常存在不

    2024年01月19日
    浏览(54)
  • Go 语言为什么不支持并发读写 map?

    大家好,我是 frank ,「 Golang 语言开发栈」公众号作者。 01 介绍 在 Go 语言项目开发中,我们经常会使用哈希表 map ,它的时间复杂度是 O(1) ,Go 语言中的 map 使用开放寻址法避免哈希碰撞。 Go 语言中的 map 并非原子操作,不支持并发读写操作。 Go 官方认为 map 在大多数情况下

    2024年02月02日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包