在C语言中如何确定一个数的溢出值是多少?
2015-07-30 17:04
417 查看
#include<stdio.h>
/*
printf("%格式符",val); 格式控制符控制了输出的格式
lf输出double类型,输出的数值的范围就是double类型的取值范围
f输出float类型 输出的数值范围就是float类型的取值范围
%d 输出int类型 输出的范围就是int的取值范围
%u 输出unsigned int类型, 输出的范围就是unsigned int的取值范围
*/
//如何计算溢出的值
int main1()
{
/*
int的取值范围 -2147483648~2147483647
*/
int r = 2147483647 + 5;
/*
数据在内存里的存储方式都是一样的,它的打印结果只有格式符的解释有关。
格式为%d就是以有符号的方式解释,第一位为符号位,显示范围为-2147483648~2147483647
格式符为%u,就是以无符号的方式进行解释,显示范围为0~4294967295
*/
printf("%d\n",r); //打印结果溢出
//输出结果 -2147483644
/*
以有符号的方式打印输出
2147483647 + 1 -2147483648
2147483647 + 2 -2147483647
2147483647 + 3 -2147483646
2147483647 + 4 -2147483645
2147483647 + 5 -2147483644
*/
printf("%u\n", r); //输出结果 2147483652
/*
以无符号的方式打印输出结果
2147483647 + 1 2147483648
2147483647 + 2 2147483649
2147483647 + 3 2147483650
2147483647 + 4 2147483651
2147483647 + 5 2147483652
*/
getchar();
return 0;
}
int main2()
{
/*
%u 的显示范围 0~4294967295
%d 的显示范围 -2147483648~2147483647
*/
unsigned int m = 4294967295 + 5;
printf("%u\n", m); //输出溢出 4
/*
以无符号的方式打印结果
4294967295 + 1 = 0
4294967295 + 1 = 1
4294967295 + 1 = 2
4294967295 + 1 = 3
4294967295 + 1 = 4
*/
printf("%d\n", m); //输出结果为4
/*
以有符号的方式打印结果
4294967295 = 2147483647 + 2147483648
%d 的显示范围 -2147483648~2147483647
4294967295 = 2147483647 + 2147483648 = -2147483648
4294967295+1 = 2147483647 + 2147483648 + 1 = -1 + 1 = 0
4294967295+2 = 2147483647 + 2147483648 + 2 = -1 + 2 = 1
4294967295+3 = 2147483647 + 2147483648 + 3 = -1 + 3 = 2
4294967295+4 = 2147483647 + 2147483648 + 4 = -1 + 4 = 3
4294967295+5 = 2147483647 + 2147483648 + 5 = -1 + 5 = 4
*/
getchar();
return 0;
}
/*
printf("%格式符",val); 格式控制符控制了输出的格式
lf输出double类型,输出的数值的范围就是double类型的取值范围
f输出float类型 输出的数值范围就是float类型的取值范围
%d 输出int类型 输出的范围就是int的取值范围
%u 输出unsigned int类型, 输出的范围就是unsigned int的取值范围
*/
//如何计算溢出的值
int main1()
{
/*
int的取值范围 -2147483648~2147483647
*/
int r = 2147483647 + 5;
/*
数据在内存里的存储方式都是一样的,它的打印结果只有格式符的解释有关。
格式为%d就是以有符号的方式解释,第一位为符号位,显示范围为-2147483648~2147483647
格式符为%u,就是以无符号的方式进行解释,显示范围为0~4294967295
*/
printf("%d\n",r); //打印结果溢出
//输出结果 -2147483644
/*
以有符号的方式打印输出
2147483647 + 1 -2147483648
2147483647 + 2 -2147483647
2147483647 + 3 -2147483646
2147483647 + 4 -2147483645
2147483647 + 5 -2147483644
*/
printf("%u\n", r); //输出结果 2147483652
/*
以无符号的方式打印输出结果
2147483647 + 1 2147483648
2147483647 + 2 2147483649
2147483647 + 3 2147483650
2147483647 + 4 2147483651
2147483647 + 5 2147483652
*/
getchar();
return 0;
}
int main2()
{
/*
%u 的显示范围 0~4294967295
%d 的显示范围 -2147483648~2147483647
*/
unsigned int m = 4294967295 + 5;
printf("%u\n", m); //输出溢出 4
/*
以无符号的方式打印结果
4294967295 + 1 = 0
4294967295 + 1 = 1
4294967295 + 1 = 2
4294967295 + 1 = 3
4294967295 + 1 = 4
*/
printf("%d\n", m); //输出结果为4
/*
以有符号的方式打印结果
4294967295 = 2147483647 + 2147483648
%d 的显示范围 -2147483648~2147483647
4294967295 = 2147483647 + 2147483648 = -2147483648
4294967295+1 = 2147483647 + 2147483648 + 1 = -1 + 1 = 0
4294967295+2 = 2147483647 + 2147483648 + 2 = -1 + 2 = 1
4294967295+3 = 2147483647 + 2147483648 + 3 = -1 + 3 = 2
4294967295+4 = 2147483647 + 2147483648 + 4 = -1 + 4 = 3
4294967295+5 = 2147483647 + 2147483648 + 5 = -1 + 5 = 4
*/
getchar();
return 0;
}
相关文章推荐
- A*寻路算法C++简单实现
- 不能将参数 2 从“TCHAR *”转换为“const char *”
- 设计模式C++实现(2)——策略模式
- 正方形计数问题(穷举+pair+struct/C++)
- 设计模式C++实现(1)——工厂模式
- C++类里面的const
- c++中size_type和size_t的关系
- C++ using关键字作用 (重载父类函数)
- C语言命令行参数识别
- C++实现将输入复制到输出的方法
- 《21天学会C++》学习笔记第7章控制程序流程
- 读书笔记MoreEffectiveC++(32)
- C++派生类为什么不能重载基类的函数
- [C++][常识]
- 多线程
- 【原文件】tinyxmlparser.cpp
- 【原文件】tinyxmlerror.cpp
- 【原文件】tinyxml.cpp
- 【原文件】tinystr.cpp
- 指针与数组的对比(——选自:C++内存管理技术内幕)