您的位置:首页 > 编程语言 > C语言/C++

在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;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: