正 文
有符号数与无符号数之间运算问题(2008/4/10 19:20)
有符号数与无符号数之间运算问题
以下实验均在virual c++6中运行通过
这个问题测试是否懂得C语言中的整数自动转换原则,有些开发者懂得极少这些东西。当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型。因此,从这个意义上讲,无符号数的运算优先级要高于有符号数,这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。
首先进行一个实验,分别定义一个signed int型数据和unsigned int型数据,然后进行大小比较:
unsigned int a=20;
signed int b=-130;
a>b?还是b>a?实验证明b>a,也就是说-130>20,为什么会出现这样的结果呢?
这是因为在C语言操作中,如果遇到无符号数与有符号数之间的操作,编译器会自动转化为无符号数来进行处理,因此a=20,b=4294967166,这样比较下去当然b>a了。
再举一个例子:
unsigned int a=20;
signed int b=-130;
std::cout<
结果输出为4294967186,同样的道理,在运算之前,a=20,b被转化为4294967166,所以a+b=4294967186
减法和乘法的运算结果类似。
如果作为signed int型数据的b=-130,b与立即数之间操作时不影响b的类型,运算结果仍然为signed int型:
signed int b=-130;
std::cout<
输出为-100。
而对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了。
评 论
17楼 52RD网友 发表于 2017/10/2 13:23 回复
好好看看书再发吧
16楼 52RD网友 发表于 2017/1/9 22:32 回复
1楼 ggggfjeicfh`(游客)说:天哪,在我的电脑上是a+b,输出-110不要用%d打,用%u
15楼 52RD网友 发表于 2015/9/27 10:55 回复
11楼 52RD网友说:我测试输出的是-110,linux环境c++默认的好像是%d输出。你用c的%u就不会错
14楼 52RD网友 发表于 2013/9/4 09:55 回复
噢买糕的,好傻
13楼 52RD网友 发表于 2013/7/31 16:14 回复
人家说的对,确实出现有符号数转换为无符号数
12楼 52RD网友 发表于 2013/7/29 15:05 回复
11楼 52RD网友说:我测试输出的是-110,linux环境请问你是怎么输出的? 如果你是这样的话: printf(%d,a+b); 那么结果很容易解释, printf函数又将无符号转成了有符号数.注意%d的含义. 建议还是看看a>b是真是假.
11楼 52RD网友 发表于 2013/7/8 20:53 回复
我测试输出的是-110,linux环境
10楼 52RD网友 发表于 2012/12/25 11:00 回复
坑人,这样的东西也敢发出来?
9楼 52RD网友 发表于 2011/10/23 18:56 回复
你的错了,应该是先进行原酸然后才进行相关的转换操作
8楼 52RD网友 发表于 2011/9/17 12:33 回复
数字之间会转化的,转化之后一般会是原来的值。值是不会变的,表示方法变了
7楼 52RD网友 发表于 2010/3/18 16:25 回复
乱说,你自己测试下再来说
6楼 52RD网友 发表于 2009/12/11 13:33 回复
一知半解就在这误人子弟 看看c标准6.2.1.1
5楼 52RD网友 发表于 2009/8/9 22:29 回复
因为printf(%d,a+b)中的%d是指打印有符号数
4楼 52RD网友 发表于 2009/5/13 18:12 回复
a+b的结果,楼主试过没有,好像是有问题的
3楼 ggggfjeicfh(游客) 发表于 2008/9/7 22:20 回复
2楼 ggggfjeicfh(游客) 发表于 2008/9/7 22:20 回复
unsigned int a = 20; signed int b = -130; printf(%d,a+b); 我的邮箱是[email protected]
1楼 ggggfjeicfh`(游客) 发表于 2008/9/7 22:19 回复
天哪,在我的电脑上是a+b,输出-110