平时写法不规范的时候,编译器都有提醒,今天不知道咋的没有提醒,就进到陷阱了,在此记录一下,也起提醒作用。
下面是抽象出来的代码,按照以下写法,会运行到Failed里面,aa-bb的值打印出来为4,比较纳闷,4>-3怎么还是进到下面的分支了。
如果使用前进行一下类型转换,改成 aa - (int32_t )bb,就会进行到正常分支,之前以为编译器会自动转换。使用minGW和VS运行结果相同
- int32_t aa = 5;
- uint32_t bb = 1;
- if ((aa - bb) > -3)
- {
- sprintf ("Passed aa-bb=%d", aa - bb);
- } ///if (aa-bb>-3)
- else
- {
- sprintf ("Failed aa-bb=%d", aa - bb);
- }///if (aa-bb>-3)
复制代码
有符号和无符号数比较还是经常能碰到的,一般都是在假定两个数都是非负数的情况下
比如 sizeof() 和 strlen() 等的值是 size_t 类型的,而实际上有时会用 int 类型存储长度 (比如有时想用负数代表其他含义),这样一比较就是有符号数和无符号数比较了
当然这样写风险肯定是有的
不一样。Keil的那个是Keil的BUG,而这个是程序员的锅。
为什么呢?
因为C语言规定了整型提升的条件。Keil中,unsigned char和signed char都是可以自动提升到int的,因此可以直接比较,只是产生的代码会变多,Keil为了降低资源占用它自己搞得不标准了。符合标准的编译器下(unsigned char) 12 > -1是必须成立的,无论是8位、16位、32位、64位的编译器。
https://www.amobbs.com/thread-5655050-1-1.html
一周热门 更多>