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; 可以看出,指针就是存放地址。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)