话不多说,直接看段代码:
#include<iostream>
using namespace std ;
static int a[] = {0,1,2,3,4,5,6,7,8} ;
int main()
{
int *p ;
// 程序段1
a[7] = 1 ;
cout<<a[7]<<++a[7]<<a[7]<<endl ;
a[7] = 1 ;
cout<<a[7]<<a[7]++<<a[7]<<endl ;
a[7] = 1 ;
cout<<a[7]<<a[7]++<<++a[7]<<a[7]<<endl ;
a[7] = 1 ;
cout<<a[7]<<a[7]--<<--a[7]<<a[7]<<endl ;
// 程序段2
p = a+3;
cout<<*p<<'\t'<<*p++<<endl ;
return 0 ;
}
程序段1输出如下:
2 2 1 // 错误认为:1 2 2 解释:cout在输出时,先从右往左进行解读,将数据(注意(1):是数据,这点看文末的链接中的第一个程序 )放入缓冲区,然后在按照你的格式从左往右开始输出。我的理解是这里的缓冲区存储是栈的情况,放入缓冲区(即入栈):从底到上依次是:1 2(++a[7],先加再放) 2 。从缓冲区取出(出栈):从上到底: 2 2 1 。
2 1 1 // 这段话的 不同在于,++a[7],变成了a[7]++ 。放入缓冲区:从底到上依次是:1 1(a[7]++,先放再加) 2 。从缓冲区取出:从上到底: 2 1 1 。
3 2 2 1 // 自己分析试试
-1 0 0 1 // 自己分析试试
程序段1输出如下:
4 3
// 和程序段1 所讲 一样,只是变成了指针而已。放入缓冲区:从底到上依次是:3(*p++,先放再加)4 。从缓冲区取出:从上到底:4 3 。
还有一些例子,其他博主说的很清楚了,推荐看看:https://www.jb51.net/article/41871.htm 这里的第一个程序也回答了我上述的 注意(1)。