局部变量的存放位置
C语言代码如下:
main()
{
char a = 'a';
char b = 'b';
char c = 'c';
int a1 = 0xa1;
int a2 = 0xa2;
int a3 = 0xa3;
char *offset_a = "1234567";
char *offset_b = "abcdef";
}
对应的汇编语言代码如下: 可以看出,前六个变量都存放在栈中,因为是局部变量;而offset_a 和offset_b存放在栈中,但是对应的值存放在0194和019c中,通过查看其内存,可以看到1234567 和abcdef存放在ds:0194的数据段中。
全局变量和字符串存放位置
int x1,x2,x3;
main()
{
char *offset_a = "1234567";
char *offset_b = "abcdef";
char a = 'a';
char b = 'b';
char c = 'c';
x1 = 0xa1;
x2 = 0xa2;
x3 = 0xa3;
}
对应的汇编代码如下: 可以看到
char *offset_a = "1234567";
char *offset_b = "abcdef";
这两个变量的值存放在段地址ds:0194和ds:019C中;而这两个变量本身在栈中存放; 再看全局变量x1,x2,x3,
x1 = 0xa1;
x2 = 0xa2;
x3 = 0xa3;
这三个变量存放在ds:01b6,ds:01b8,ds:01ba 的位置。
指针的实质
通过上面的分析,可以看到指针的实质就是地址,char *offset_a = "1234567"; 对应的汇编语言为:mov word ptr [BP-8],0194 ; 那就相当于,char *offset_a = ds:0194 ; 可以看出,指针就是存放地址。
|