Chinaunix首页 | 论坛 | 博客
  • 博客访问: 299145
  • 博文数量: 148
  • 博客积分: 4365
  • 博客等级: 上校
  • 技术积分: 1566
  • 用 户 组: 普通用户
  • 注册时间: 2008-07-05 21:38
文章分类
文章存档

2014年(2)

2013年(45)

2012年(18)

2011年(1)

2009年(54)

2008年(28)

我的朋友

分类: C/C++

2009-09-03 19:19:26

如何确定你的编译采用的那种顺序?
#include
int f(int i,int j,int k);
int main()
{
static int i=0;
f(i++,i++,i++);
return 0;
} int f(int i,int j,int k)
{
int l;
int g;
printf("k=%d:[%x]\n",k,&k);
printf("j=%d:[%x]\n",j,&j);
printf("i=%d:[%x]\n",i,&i);
printf("___________\n");
printf("l:%x\n",&l);
printf("g:%x\n",&g);
}
看看k->i的地址的增长顺序和l->g的顺序是否相同,如果相同则是从右到左,否则从左到右.

输出
k=0:[22ff78]
j=1:[22ff74]
i=2:[22ff70]
___________
l:22ff64
g:22ff60
从右到左说明。C++中栈底为高地址。栈顶为低地址
不过这个最主要还是和编译器有关,详细可参见下文章
阅读(574) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~