C语言个人学习笔记(一)
在汇编程序中,一个函数的开头常常见到以下代码:
8048cbd: 83 ec 18 sub $0x18,%esp
这句话的目的是分配栈帧。栈帧中存放的是程序中的局部变量。在windows的编译器cl.exe中这些栈帧中的值最初会被初始化为0xcc,这也是为什么VC++在数组越界或访问未赋值的内存时打印“烫烫烫”的原因(0xcccc在GBK下显示为烫烫烫)
程序中,整型字面量的值被编译成立即数存在代码段中,如果该整型字面量值过长则代码段中只会截取一部分。
字符串字面量、浮点型字面量的值存在静态常量区。
入栈时,高字节先入栈低字节后入栈。
以下代码:
8048cba: 55 push %ebp
8048cbb: 89 e5 mov %esp,%ebp
是为了保存调用者函数的栈底地址
返回函数的指针不能返回局部变量的地址,例如,以下代码会打印乱码:
#include <stdio.h>
char *returnStr()
{
char p[]="hello world!";
return p;
}
int main()
{
char *str=NULL;//一定要初始化,好习惯
str=returnStr();
printf("%s\n", str);
return 0;
}
2019年6月22日
written by:Sullivan