前提知识
c0s调用main函数的地址: 11ah
main函数的连接地址: 01fah
一、全局变量与局部变量
测试程序
int a1,a2,a3;void f(void);void g(void);void h(void);main()
{int b1,b2,b3; a1 = 0xa1;a2 = 0xa2;a3 = 0xa3;
b1 = 0xb1;b2 = 0xb2;b3 = 0xb3;
}
void f(void)
{int c1,c2,c3; a1 = 0x0fa1;a2 = 0x0fa2; a3 = 0x0fa3;
c1 = 0xc1;c2 = 0xc2; c3 = 0xc3;
c1 = c2 + c3;}
void g(void)
{int i = 100; while(i--);}
void h(void)
{int h1,h2,h3,h4,h5,h6,h7; h1 = 0xc1;h2 = 0xc2; h3 = 0xc3;h4 = 0xc4;
h5 = 0xc5;h6 = 0xc6; h7 = 0xc7;
h1 = h2 + h3; h2 = h3 + h4;}
View Code
编译、连接后,用debug调试这段代码,根据函数分别贴出对应的反汇编代码
1、main函数
(1)全局变量
main()
{intb1,b2,b3;
a1= 0xa1;a2 = 0xa2;a3 = 0xa3;
b1= 0xb1;b2 = 0xb2;b3 = 0xb3;
}
对应的反汇编代码
可以看到全局变量,a1、a2、a3的地址分别是ds:[01a6]、ds:[01a8]、ds:[01aa]。