关于sizeof()里面的坑

本文探讨了C++中sizeof操作符的特性和逻辑运算符(&&和||)在表达式求值中的行为。通过实例代码解释了sizeof并不实际执行变量的递增操作,而是一个编译时操作。同时,逻辑运算符在遇到已知结果时不会计算后续表达式,导致后置递增操作未执行。这些知识点对于理解和避免编程陷阱至关重要。
摘要由CSDN通过智能技术生成

sizeof很简单,但是却很容易令人踩坑。

正文

先来看这样一段代码

int main()
{
int i=2;
printf("%d\n",sizeof(i++));
printf("%d\n",i);
return 0;
}

非常简单的一段代码
当时我认为答案应该是

4
3

可是结果却是出乎我的意料了

这是为什么呢?
下面来仔细说一下
在这里插入图片描述
在这里插入图片描述

通过调试观察虽然确实有i++这么一句代码,但是却没有实现。说到这里很多人可能犯了和我一样的错误,认为sizeof是一个函数。
其实并非如此,sizeof其实是单目操作符的一种,可以求变量类型所占用的空间,单位是字节。

说到这里就应该和strlen函数区分开,strlen函数求的是字符串的字符数,不包括’\0’,而sizeof由于求的是字节数,会将’\0’计算上。

再说几个与sizeof这种情况类似的,避免踩坑。
逻辑操作符 &&和 ||也会产生这样的坑

来看这样一道题

int main()
{
	int i = 0, a = 0, b = 2, c = 3, d = 4;
	i = a++ && ++b && c++;
	//i = a++||++b||c++;
	printf("a = %d\nb = %d\nc = %d\n", a, b, c);
	return 0;
}

答案:请添加图片描述

这里大家或许就有疑问了,这个b为什么不等于2呢,这个c为什么不等于4呢,这不是后置++了吗?

其实逻辑操作符在运算过程中并不会把每个对象都计算到,就拿这个举例子,由于是后置++,a此时还等于0,对于&&逻辑与来说,答案已经显而易见了,0和任何数逻辑与都等于0。所以后面的b++,和c++并没有被计算到。

我想逻辑或也是同理吧,只有有一个”真“,逻辑或得到的就是”真“。
这就意味着c++并没实现。
在这里插入图片描述

  • 29
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 28
    评论
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值