博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C语言:C语言中的整数自动转换原则(转)
阅读量:4661 次
发布时间:2019-06-09

本文共 833 字,大约阅读时间需要 2 分钟。

有符号数与无符号数之间运算问题
以下实验均在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<<a+b<<std::endl;
结果输出为4294967186,同样的道理,在运算之前,a=20,b被转化为4294967166,所以a+b=4294967186
减法和乘法的运算结果类似。
如果作为signed int型数据的b=-130,b与立即数之间操作时不影响b的类型,运算结果仍然为signed int型:
signed int b=-130;
std::cout<<b+30<<std::endl;
输出为-100。
而对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了
 

转载于:https://www.cnblogs.com/zzzili/archive/2012/12/06/6662860.html

你可能感兴趣的文章
北漂随笔 01
查看>>
[小知识点]绝对路径与相对路径.
查看>>
C#_DataGridView之导出到Excel
查看>>
selenium 代码常见报错
查看>>
fatal error LNK1103: debugging information corrupt; recompile module 解决
查看>>
在不兼容IE中推动发展
查看>>
Too many arguments provided to function-like macro invocation 或
查看>>
代码大全读后感(三)
查看>>
Java中23种设计模式详解
查看>>
Codeforces 988F Rain and Umbrellas 【dp】
查看>>
腾讯2009年笔试题
查看>>
'config.h' file not found 解决过程
查看>>
在VSCode中配置Eslint格式化
查看>>
建造者模式 详解
查看>>
eclipse启动不了
查看>>
[USACO11JAN]利润Profits
查看>>
播放视频有沙沙的杂音怎么处理?
查看>>
工作后学习到的开发经验
查看>>
码猿的初审。。。
查看>>
SQL分页
查看>>