cout的执行顺序以及i++与++i的深刻理解

cout的执行顺序以及i++与++i的深刻理解
i++与++i的区别
cout的执行顺序
先看这样一个例子:


i++与++i的区别
i++,俗称先用后加;++i,俗称先加后用。
i++不可以做左值,++i可以做左值。
但是这是为什么呢?
我们先来看一下他们的具体实现:
i++ :

const int int::operator++(int){
    int old = *this;
    ++(*this);
    return old;
}
1
2
3
4
5
++i :

int& int::operator++(){
    *this += 1;
    return *this;
}
1
2
3
4
前缀形式(++i)返回的是引用形式,也就是一个地址值,说明函数的返回值可以作为左值使用,并且函数本身是无参的,意味着是在自身所在的空间增一后,再将自身的引用返回。
而后缀形式(i++)是带参的,说明在刚进入函数的时候存在另外的空间开辟,先将传入的值复制到一个副本中,将自身空间原本对应位置的值增一,最后返回的是副本的值。由于在函数的返回值传递的时候是进行值传递的,因此返回值只是一个临时变量,并不可以作为左值使用。

cout的执行顺序
cout输出的时候,先从右往左扫描,将数据读入缓冲区,然后再将缓冲区的内容依次输出。缓冲区是一种类似于栈的结构,满足先进后出的特性。
(据说在某些编译器上不是这个样子的)

因此分析一下上面图中的例子:
初始值i = 0
cout << "i++ : " << i++ << ", i++ : " << i++ << endl;
先扫描到第二个i++,i变为1,此时i++返回值为0,则0入缓冲区:|0|
然后扫描到第一个i++,i变为2,此时i++返回值为为1,则1入缓冲区:|0|1|
输出(按照栈的先进后出特性):1 0
此时i=2
cout << "++i : " << ++i << ", ++i : " << ++i << endl;
先扫描到第二个++i,i变为3,此时返回i的引用,缓冲区:|&i|
然后扫描到第一个++i,i变为4,此时返回i的引用,缓冲区:|&i|&i|
输出时,i此时的值为4,因此输出的时候从i对应的地址中读取数据,则输出:4 4
此时i=4
cout << "++i : " << ++i << ", i++ : " << i++ << ", ++i : " << ++i << endl;
略!
————————————————
版权声明:本文为CSDN博主「佳潇翔」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_40024275/article/details/100524036

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值