c语言数据溢出怎么办

2024-11-21 04:56:51
推荐回答(5个)
回答1:

C语言的强大之处就在于他的灵活性,程序员自己把握。编译器可以帮助预防错误,但有些程序会利用溢出,所以溢出不完全是错误的事情。
1、溢出:
数据类型超过了计算机字长的界限而出现的数据溢出;
2、溢出可能原因:
当应用程序读取用户数据,复制到应用程序开辟的内存缓冲区中,却无法保证缓冲区的空间足够时 (假设定义数组int Array[10], 而在调用时使用Array[11] 或存放的数据超过int类型容量等), 内存缓冲区就可能会溢出.
3、溢出因素分析:
由于C/C++语言所固有的缺陷,既不检查数组边界,又不检查类型可靠性,且用C/C++语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,只要合理编码,C/C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++语言导致内存溢出问题的可能性也要大许多。

回答2:

这个问题就好比:我感冒了怎么办?
我的意思是,你要做的就是防止数据溢出。在为数据赋值的时候,要记住这个类型容纳的数据的上下限,在使用字符串的时候,记住为末尾的'\0'字符留个一个字符的位置,等等。
这应该是自然反应,但这个过程需要慢慢积累,所以,多写代码是有好处的。

回答3:

显然对于比较大的a,这个数字c是个很大的数字,所以你不能用自带的数据类型,长整型也不够用。你需要自己定义数组,将每一位数字存到一个单元里面,但是相应地,做加减乘除计算的部分你也要自己写,不会的话,你可以搜索一下数组的加减乘除运算,应该可以搜到相关的算法。

回答4:

经测试,程序是没有错的。但是输入的a不能太大了。

我输入5,结果就已经是114了,所以不能输入太大的数。

回答5:

long int 4字节,换long long