注意内存小于4个字节,会放入寄存器上
注意:在堆区开辟内存的时候,内存就已经随机赋值了,因此可以用memset清空内存
1.不要返回局部变量的地址 vs编译器会先保留一次局部变量地址,防止程序员误操作 内存已经被释放,再操作属于非法行为 注意返回地址用指针接收,与返回值用变量接收的区别:
解决方法:返回静态变量,静态变量生命周期直到程序结束
2.不要操作已经释放的内存空间 不能再释放后*p=2000;再次操作释放的内存空间
free(str)后指针仍然指向原来的堆地址,即你仍然可以继续使用,但很危险,因为操作系统已经认为这块内存可以使用,他会毫不考虑的将他分配给其他程序,于是你下次使用的时候可能就已经被别的程序改掉了,这种情况就叫“野指针”,所以最好free()了以后再置空 str = NULL; 即本程序已经放弃再使用他。 何谓“野指针”,在这里补充一下。
野指针是指程序员或操作者不能控制的指针。野指针不是NULL指针,而是指向“垃圾”的指针。 造成“野指针”的原因主要有 1.指针变量没有初始化,任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。在初始化的时候要么指向合法的指针,要么指向NULL。 2.指针变量被free或delete之后,没有设置为NULL。它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。通常会用语句if (p != NULL)进行防错处理。很遗憾,此时if语句起不到防错作用,因为即便p不是NULL指针,它也不指向合法的内存块。上文DEMO则是这种情况。 3.指针操作超越了变量的作用范围。 注意其生命周期。
free释放的不是指针,而释放的指针指向的内存空间。free之后,如果指针又指向了另一块内存空间,可以直接使用该内存空间的数据。而如果free之后指针没有指向其他内存空间,也没有指向NULL,依旧指向着已被释放的内存空间,所以操作数据会出错。一般在free之后都需要重新指向新的内存空间或NULL
解决方法:
void fun()
{
int* p = (int*)malloc(sizeof(int));
if (p != NULL)
{
free(p);
p = NULL;
}
//空指针也可以释放
free(p);
}