0){printf("yes\n")" />
C语言的int类型与unsigned int运算的问题。 |
您所在的位置:网站首页 › 字母与数字相乘怎么表示有何规则和特点 › C语言的int类型与unsigned int运算的问题。 |
一、unsigned int变量跟int类型的变量运算时得出的结果是什么类型的? 1、先看一个有趣的例子: int a = 3; unsigned int b = -6; printf("%d\n", a+b); if((a+b)>0) { printf("yes\n"); } else { printf("no\n"); } return 0; } 运行结果: -3 yes看到这个运行结果,很多小伙伴开始疑惑了?unsigned int类型怎么可以赋值一个-6?既然打印出来结果是-30) 判断中,(a+b)中并没有指定读取的类型,所以就进行隐式转换,a就转成unsigned int类型,也就是3;b转成unsigned int类型,因为b本来的存储是1111 1111 1111 1010(32位机下),转成unsigned int类型时不考虑符号位,所以就直接以补码的形式转化,也就是65530(32位机下),所以a+b=65533>0,输出yes。 有趣的例子2: int a = -6; unsigned int b = 3; if((a+b)>20) { printf("yes\n"); } else { printf("no\n"); } return 0; 运行结果: yes(3)代码分析: 按照刚刚的分析,a+b会隐式转换成为unsigned int类型,a转换成为unsigned int类型以后也就是-6的补码直接转换,为65530(32位机下)。b本身为unsigned int,也就是3,所以a+b=65533(32位机下),所以输出yes。 二、总结 ①当一个int类型的a与unsigned int类型的b相运算时,例如:a+b的时候,如果直接是a+b的话,各个变量就会隐式转换成为unsigned int的类型再相加。 ②当用print函数指定打印的时候,例如:printf(”%d\n”,a+b),就要各个变量转换为%d的类型再想加。 ③当用一个int c类型去装这个结果时,如:c=a+b,同理,a和b会根据c的类型去分别转换跟c一致的类型再去运算。 |
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |