*p++,*++p,++*p

*p++,*++p,++*p

转载自http://blog.csdn.net/fooolboy/archive/2009/04/13/4070715.aspx

#include <iostream.h>
int main(){
 char s[] = "012345678", *p = s;

 cout << *p++ << *(p++) << (*p)++ << *++p << *(++p) <<++*p << ++(*p) << endl;
 
 p = s;
 cout << *p++ << endl;
 cout << *(p++) << endl;
 cout << (*p)++ << endl;
 cout << * ++p << endl;
 cout << *(++p) <<endl;
 cout << ++*p << endl;
 cout << ++( *p) <<endl;
 return 0;
}
VC++6 DEBUG下分析:cout的运算是从右向左进行的,但最后输出还是从左到右。所以cout << *p++ << *(p++) << (*p)++ << *++p << *(++p) <<++*p << ++(*p) << endl;依次++(*p),++*p,
*(++p),*++p,(*p)++,*(p++), *p++ ,最后再反着输出。
1.++*p:P指向S[0],并把S[0]加1做为表达式的值,所以输出为1,此时S[0]=='1'
2.++(*p):P还指向S[0](S[0]现在的值为1),并把S[0]加1做为表达式的值,所以输出为2,此时S[0]=='2'
3.*(++p):p指向S[1],然后取S[1]的值作为表达式的值,输出'1'
4.*++p :P指向S[2],然后取S[2]的值作为表达式的值,输出'2'
5.(*p)++:P还是指向S[2],取S[2]的值作为表达式的值,所以输出'2',然后S[2]的值加1,S[2]==3
6.*(p++):P还是指向S[2](现值为3),取S[2]的值作为表达式的值,所以输出'3',然后P指向S[3]
7.*p++ :P指向S[3],取S[3]的值作为表达式的值,所以输出'3',然后P指向S[4];
最后反着输出为3322121
此数组S的值为"213345678".所以后面的输出就是这些值了。

2009.6.6

这程序看起来不爽,自己弄了一个,

// p++.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <iostream>
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
 
 char  a[]="05";
 char * p = a;
 cout <<*p++<< endl;

 cout<<a[0]<<a[1]<<endl;
 cout <<hex<<(unsigned   long)a<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*输出结果是

0

05
13ff60
13ff61

先输出当前所指地址的值,然后地址增加

*/

 char  b[]="05";
 p = b;
 cout << *(p++)<< endl;

 cout<<b[0]<<b[1]<<endl;
 cout <<hex<<(unsigned   long)b<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*输出结果是

0

05
13ff48
13ff49

先输出当前所指地址的值,然后地址增加

*/


 char  c[]="05";
 p = c;
 cout << (*p)++<<endl;

 cout<<c[0]<<c[1]<<endl;
 cout <<hex<<(unsigned   long)c<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*输出结果

0

15
13ff3c
13ff3c

输出当前所指地址的值,然后该值+1,指针所指地址不变

*/

 char  d[]="05";
 p = d;
 cout << * ++p<<endl;

cout<<d[0]<<d[1]<<endl;
 cout <<hex<<(unsigned   long)d<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*

5

05

13ff30
13ff31

地址增加后,输出该地址对应的值

*/

 char  e[]="05";
 p = e;
 cout << *(++p)<<endl;

 cout<<e[0]<<e[1]<<endl;
 cout <<hex<<(unsigned   long)e<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*

5

05
13ff24
13ff25

地址增加后,输出该地址对应的值

所以,* ++p和*(++p)是一回事,括号算是白加了

*/

 char  f[]="05";
 p = f;
 cout << ++*p << endl;

 cout<<f[0]<<f[1]<<endl;
 cout <<hex<<(unsigned   long)f<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*

1

15
13ff18
13ff18

将p地址对应的值加1,地址保持不变

将(*p)当成一个变量,一目了然

*/

 char  g[]="05";
 p = g;
 cout << ++( *p)<<endl;

cout<<g[0]<<g[1]<<endl;
 cout <<hex<<(unsigned   long)g<< endl;
 cout <<hex<<(unsigned   long)p<< endl<<endl;

/*

1

15
13ff0c
13ff0c

将p地址对应的值加1,地址保持不变

++( *p)和++*p也是一回事......

*/
 system("pause");
 return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值