c语言大华面试题,大华股份的一道笔试题 C/C++

本文详细分析了一段C++代码,指出在混合使用unsigned int和int类型进行加法运算时,由于类型提升规则导致的逻辑错误。在32位机器上,当unsigned int和负数int相加时,负数int会被转换成一个非常大的无符号整数,从而使得条件判断结果出乎意料。通过深入理解二进制表示和类型转换,解释了为何程序未进入预期的else分支,并讨论了逗号表达式在程序中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面这段程序调试了之后结果显示为 5,-7,-2;

#include"stdio.h"

#include"iostream"

using namespacestd;

int main(void)

{

unsigned int a=5;

int b=-7,c=4;

if(b+a>0)

c=a+b,b=c-a;

else

c=a-b,b=c+a;

cout<

return 0;

}

本以为结果会是c=12,b=17,a=5不变。主要是因为b+a等于-2是小于零的,进入else中执行。在VISUAL C++中单步调试后发现实际上程序在if判断后进入了if语句。即b+a是大于零成立的。为什么没有进入else呢?重新观察代码后,知道a变量时unsignedint类型,而b是int类型,二者相加之后到底结果是什么类型呢?这就涉及到了不同类型变量运算时类型提升的一个问题!

两个不同类型的变量相加,结果的类型应该遵循下面的原则:相加的变量中,哪个类型能表示的数值更大,结果就转换为哪个类型。Short+long ,结果就要转换为long。对与unsigned int与int类型相加,在32位机器上,unsigned int能表示的最大值是2^32-1,int最大可表示2^31-1.因为结果应该转换为unsignedint 类型。这样相加时,int提升为unsignedint。

unsigned int a=5; int b=-7;b为负值,最高位为1,转换为无符号整型后,最高位不再表示符号,而是表示该类型的数值,是一个很大的正数,所有二者相加的结果也是一个很大的整数。于是理所当然的进入if语句。

在if和else分支中,用到了逗号表达式,例如:

c=a+b,b=c-a;先执行c=a+b,再执行b=c-a,整个表达式的最终值是最后一个表达的值,若int resullt=(c=a+b,b=c-a);则结果result与b的值一样。

二进制表示:

unsignedint a=5;红色

int b=-7;黑色

补码:00000000 00000000 00000000 00000101

原码:10000000 00000000 0000000 00000111

补码:111111111 11111111 11111111 11111001

补码相加:11111111 11111111 11111111 11111110

转换为c的类型,c是int;

最高位是1,是负数,补码转换为原码

先减一再取反

11111111 11111111 11111111 111111101

10000000 00000000 00000000 00000010

就是-2即是c的结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值