c语言的汇编表示(变量的存储)day_03
c源码
int main ()
{
char a=1;
char* pa = &a;
}
汇编代码
char a=‘c’;
00BC1903 mov byte ptr [ebp-5],1
char* pa = &a;
00BC1907 lea eax,[ebp-5]
00BC190A mov dword ptr [ebp-0Ch],eax
其堆栈形式:
ebp-0c e7 ->pa首地址
ebp-0b fc
ebp-0a d6
ebp-9 00
ebp-8 垃圾数据
ebp-7 垃圾数据
ebp-6 垃圾数据
ebp-5 01 ->a首地址
pa内部的值打印出来为 0x00d6fce7
很明显windows内部存储为小端存储(高地址对应高字节,低地址对应低字节),其变量的地址内部存储的部分是该变量的小端部分,大端存储与此相反
char 是一个字节,再汇编的代码中可以看出为了字节对齐,存储a实际用了四个字节,由于我关闭了缓冲区检查(编译器没有在缓冲区填充0xcc),所以该部分保留的是垃圾数据,并不是我想的0x00000001;