c/c++ 运算溢出问题
2个回答
展开全部
C语言的强大之处就在于他的灵活性,程序员自己把握。编译器可以帮助预防错误,但有些弊橡程序会利用溢出,所以溢出不完全是错误的事情。
1、溢出:
数据类型超过了计算机字长的界限而出现的数据溢出;
2、溢出可能原因:
当应用程序读取用户数据,复制到应用程序开辟的内存缓冲区中租穗旁,却无法保证缓冲区的空间足够时
(假设定义数组int
Array[10],
而在调用时使用Array[11]
或存放的数据超过int类型容量等),
内存缓冲区就可能会溢出.
3、溢出因素分析:
由于C/C++语言所固有的缺陷,既不检查数组边界,又不检查类型可靠性,且用C/C++语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,只要合理编码,C/族拆C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++语言导致内存溢出问题的可能性也要大许多。
1、溢出:
数据类型超过了计算机字长的界限而出现的数据溢出;
2、溢出可能原因:
当应用程序读取用户数据,复制到应用程序开辟的内存缓冲区中租穗旁,却无法保证缓冲区的空间足够时
(假设定义数组int
Array[10],
而在调用时使用Array[11]
或存放的数据超过int类型容量等),
内存缓冲区就可能会溢出.
3、溢出因素分析:
由于C/C++语言所固有的缺陷,既不检查数组边界,又不检查类型可靠性,且用C/C++语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,只要合理编码,C/族拆C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++语言导致内存溢出问题的可能性也要大许多。
展开全部
a/2等价于a<<1,即相当于a的二进制右移一位
如果一个数是奇数,则二进腔中洞制位的最低位一定为1,否则为0。因此用a%2就可以得到数a的最低位。
程序的思路其实是这样的:
(1)如果数a的最低位为1(a%2==1),则让num++
否则不用加(因为最低位是0)
(2)
让a右移一位(a>>1),让次低位变成最低位,重复(1),直到所有位处理完毕(即a==0)
以一个4位的整数为例(如10),其二进制为1010,
第一次循环:10%2==0(1010最低位为0),num=0,然后右移数a,变为0101(就是5了)
第二次循环:培孙5%2==1(0101最低位1),num=1,然后右移数a,变为0010(就是2了)
第三伍枯次循环:
2%2==0(0010最低位为0),num=1,然后右移数a,变为0001(就是1了)
第四次循环:
1%2==1(0001最低位为0),num=2,然后右移数a,变为0000(就是0了)
因a==0,所以程序结束。
如果一个数是奇数,则二进腔中洞制位的最低位一定为1,否则为0。因此用a%2就可以得到数a的最低位。
程序的思路其实是这样的:
(1)如果数a的最低位为1(a%2==1),则让num++
否则不用加(因为最低位是0)
(2)
让a右移一位(a>>1),让次低位变成最低位,重复(1),直到所有位处理完毕(即a==0)
以一个4位的整数为例(如10),其二进制为1010,
第一次循环:10%2==0(1010最低位为0),num=0,然后右移数a,变为0101(就是5了)
第二次循环:培孙5%2==1(0101最低位1),num=1,然后右移数a,变为0010(就是2了)
第三伍枯次循环:
2%2==0(0010最低位为0),num=1,然后右移数a,变为0001(就是1了)
第四次循环:
1%2==1(0001最低位为0),num=2,然后右移数a,变为0000(就是0了)
因a==0,所以程序结束。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询