代码执行过程
源代码——编译器——汇编语言(obj)——链接(Link)——可执行文件(文件格式与平台相对应)
编译时可能会产生不一样的代码,因为编译器会对代码进行优化。
汇编会把代码简单化:
汇编代码一般包括:赋值语句,跳转语句,计算语句。
Release是发布版,执行快速,精悍,占用空间小,会对代码进行简化。
调试的时候最好用Debug它会对每句代码生成对应的汇编。
两种测试方法产生的结果是一样的
程序执行产生的文件分层:
栈(存放临时变量,默认分配1024KB,可增长),堆,代码,常量。
代码和常量区只读不写,这样就能防止程序被破坏。
栈的释放,划分出一个内存区域,利用游标,EBP栈底、ESP栈顶,每次需要清除临时变量时把ESP下移与EBP重合,把之前空间清除存入新的变量。
push压栈