一.实验程序
#include "iostream"
using namespace std;
int main(int argc, char* argv[])
{
int value=45;
int *pt1=&value;
int **pt2=&pt1;
cout<<"addr1:"<<&value<<" "<<"value1:"<<value<<endl;
cout<<"addr2:"<<&pt1<<" "<<"value2:"<<*pt1<<endl;
cout<<"addr3:"<<&pt2<<" "<<"value3:"<<**pt2<<endl;
return 0;
}
二.实验结果
addr1:0012FF7C value1:45
addr2:0012FF78 value2:45
addr3:0012FF74 value3:45
三.结果分析
在调用此函数的过程中,所有的局部变量value,pt1,pt2均放在栈中,而栈中的内存分配按照从高位向低位分配,因而&value,&pt1,&pt2的关系:&pt2+4=&pt1;&pt1+4=&value;
注:int变量占用4字节的内存.