合合电话面试的一些知识点

来源:互联网 发布:爱的算法txt 编辑:程序博客网 时间:2024/04/29 01:57

1.堆和栈的区别

栈区——由编译器自动分配释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构的栈

堆区——由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。与数据结构的堆是两回事,分配方式类似于链表。

全局区(静态去)(static)——全局变量和静态变量是存储在一块的。初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始化的静态变量在另一块区域,程序结束后由系统释放。

文字常量区——常量字符串就是存储在这里,程序结束后由系统释放。

程序代码区——存放函数体的二进制代码。

例子:

这段代码在将get_memory()的返回值赋给指针p的时候,p指向函数返回的指针所指向的数组首地址(本次运行时为0x002df96c,每次运行时不同),此时*p=‘H’。当程序执行到输出指针p的时候,栈区指针回指,get_memory()及其返回值一并退栈。此时p仍然指向0x002df96c,但这块内存中的数据有可能会被其他进程覆盖,具体结果与编译器有关,本机输出p的值为


2.关于const和非const形参

直接上例子:

运行后结果

事实证明,不管形参是const还是非const,你都可以随便传实参,两者的区别仅在于函数中const形参不可修改而非const形参则可以修改。事实上,编译器把TestForConst(cont int a)视为TestForConst(int a)。

 

3.malloc,calloc和realloc的区别

三个函数的声明分别是:

void* realloc(void* ptr, unsigned newsize);

void* malloc(unsigned size);

void* calloc(size_t nelem, size_t elsize);

都在stdlib.h函数库内
它们的返回值都是请求系统分配的地址,如果请求失败就返回NULL

malloc用于申请一段新的地址,参数size为需要内存空间的长度,如:

char* p;

p=(char*)malloc(20);

calloc与malloc相似,参数elsize 为申请地址的单位元素长度,nelem为元素个数,如:

char* p;

p=(char*)calloc(20, sizeof(char)); 

这个例子与上一个效果相同

realloc是给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址长度

 

其他的暂时想不起来了,想起来了再补充。