一、malloc开辟空间,realloc增加空间内存
//Test8.c
#include<stdio.h>
#include <stdlib.h>
#include <string.h>
// char *strcpy(char *dest, const char *src);
// void *malloc(size_t size);
// void free(void *ptr);
// void *calloc(size_t nmemb, size_t size);
// void *realloc(void *ptr, size_t size);
int main()
{
char *p;//野指针
p = (char *)malloc(1);//p有了具体的内存指向,并且malloc被强转成char *型
*p = 'c';
free(p);//释放刚才开辟的内存
p = NULL;
p = (char *)malloc(12);
if(p==NULL)
{
printf("malloc error\n");
exit(-1);
}
memset(p,'\0',12);//把刚才开辟的空间全赋值为0
printf("需要扩容地址:%p\n",p);
char *arr = "I will be successful";
int len = strlen(arr);
int new_len = len -12 +1;
char *b = realloc(p,new_len);
printf("扩容后的地址:%p\n",p);
strcpy(p,arr);
puts(p);
free(b);
return 0;
}
~
输出结果:
二、野指针
野指针就是指针指向的位置是不可知的(随机的、不正确的、没有明确限制的)指针变量在定义时如果未初始化,其值是随机的,指针变量的值是别的变量的地址,意味着指针指向了一个地址是不确定的变量,此时去解引用就是去访问了一个不确定的地址,所以结果是不可知的。
野指针主要是因为这些疏忽而出现的删除或申请访问受限内存区域的指针。
- 指针变量未初始化:
任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。如果没有初始化,编译器会报错“ ‘point’ may be uninitialized in the function ”。
- 指针释放后之后未置空:
有时指针在free或delete后未赋值 NULL,便会使人以为是合法的。别看free和delete的名字(尤其是delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。此时指针指向的就是“垃圾”内存。释放后的指针应立即将指针置为NULL,防止产生“野指针”。
如何最大可能规避这种风险呢?
在养成这些习惯的情况下,野指针的危害是可以降低的:
- 初始化时置 NULL
指针变量一定要初始化为NULL,因为任何指针变量(除了static修饰的指针变量)刚被创建时不会自动成为NULL指针,它的缺省值是随机的。
- 释放时置 NULL
当指针p指向的内存空间释放时,没有设置指针p的值为NULL。delete和free只是把内存空间释放了,但是并没有将指针p的值赋为NULL。