后置自增操作符与解引用,前置自增操作符

7 篇文章 0 订阅
char a[ ] = "Hello";
char *p = a;
int i = strlen(a);
while(i > 0){
printf("%c", *p++);
++i;
}
1 之前一直以为printf("%c", *p++);这句话是先解引用再将p指针++的,
但是我还是太年轻了,不然怎么会有Hello而不是ello呢?
2 但是,运算符的优先级显示后置自增操作符(++) 优先级高于解引用(*)
那么输出应该是ello才对啊,但是输出却是Hello
3 因为*p++ 等价于*(p++)没错,只是p++把p的值加1,然后返回p的初始值的

副本作为其求职结果,此时解引用运算符对象是p未增加之前的值。

//================================

NOTE:

除非必要,否则不用递增递减的运算符的后置版本

前置版本递增(或递减)运算符将对象本身作为左值返回,
后置版本则将对象原始值的副本作为右值返回。
建议:除非必须,否则不用递增递减运算符的后置版本。
只是原因非常简单:前置版本的递增运算符避免了不必要的工作,
它把值加1后直接返回改变了的运算对象。
与之相比,后置版本需要将原始值存储下来以便于返回这个未修改的内容。
如果我们不需要修改前的值,那么后置版本的操作就是一种浪费。
对于整数和指针类型来说,编译器可能对这种额外的工作进行了一定的优化;
但是对于相对复杂的迭代器类型,这种额外的工作就消耗巨大了。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值