日期:2014-05-16  浏览次数:20528 次

相同的程序,每次运行时,栈都是从同一个地址开始的吗?
估计我没有说清楚..
是这样的     有下面一个程序
//sp.c

unsigned   long   find_sp(void){
    __asm__( "movl   %esp,   %eax ");
}
int   main(int   argc,char*   argv[]){
char*   buff;
int       len;
long   sp;
len=atoi(argv[1]);
buff=malloc(len);
sp=find_sp();
printf( "sp   is   0x%x\n ",sp);
free(buff);
exit(0);

}

然后我每次运行   ,输入相同的参数   然而输出的结果每次都不同

比如  
./sp   300

请问是怎么回事呢

------解决方案--------------------
哥们对不起了。我还没有对这方面下功夫
------解决方案--------------------
堆栈是程序加载的时候由操作系统初始化的,每次应该不同。
------解决方案--------------------
对OSd: stack应该每次都不一样的内存地址,不过对于每个进程空间来说,它的起初位置是一样的,从0x0开始
------解决方案--------------------
知道这个有意义吗?向你学习中。。。
------解决方案--------------------
mark……
------解决方案--------------------
挺奇怪
感觉应该是相同的