【转】一定要搞死GetMemory()

来源:互联网 发布:linux 电池电量 编辑:程序博客网 时间:2024/06/14 08:16

转载过来,无法分辨对错,求指正。


首先是,所有代码均无作申请内存失败的处理,应添加代码:
if(p!=NULL){    // 把所有操作用此语句包裹}


NO1
void GetMemory(char *p){       p=(char *)malloc(100);}void Test(){  char * str=NULL;  GetMemory(str);  strcpy(str,"Hello world");  printf(str);}

实质:GetMemory(str)在调用时会生成一个_str与str指向同一个数,这是因为C语言中函数传递形参不改变实参的内容,但是指针指向的内容是相同的,因此可以用指针控制数据。题中的GetMemory(str),实质是对_str的操作,并没有对str操作,函数结束后_str撤销,因此不会产生新的内存空间,str仍然是一个空指针。
 
NO2
char *GetMemory(){       char p[]="Hello World";       return p;}void Test(){       char * str=NULL;       str=GetMemory();       printf(str);}

实质:当一个函数调用结束后会释放内存空间,释放它所有变量所占用的空间,所以数组空间被释放掉了,也就是说str所指向的内容不确定是什么东西。但是返回的指针指向的地址是一定的。
 
NO3
char *GetMemory(){       Return “hello world”;}void Test(){       char * str=NULL;       str=GetMemory();       printf(str);}

实质:本例打印hello world,因为返回常量区,而且并没有修改过。在上一个例子中不一定能打印hello world,因为指向的是栈区。
 
NO4
void GetMemory(char **p,int num){       *p=(char *)malloc(num);}void Test(){       char * str=NULL;       GetMemory(&str,100);       strcpy(str,"Hello");       printf(str);}

可以正确的打印Hello但是内存泄露了,在GetMemory()中使用了malloc申请内存,但是在最后却没有对申请的内存做任何处理,因此可能导致内存的泄露,非常危险。
 
NO5
void Test(){       char *str=(char *)malloc(100);       strcpy(str,"Hello");       free(str);       if (str!=NULL)       {              strcpy(str,"World");              printf(str);       }}

申请空间,拷贝字符串,释放空间,前三步操作都没有问题,到了if语句里的判断条件开始出错了。因为一个指针被释放了之后其内容并不是NULL,而是一个不确定的值,所以if语句永远不能被执行,这也是著名的“野”指针问题。
0 0
原创粉丝点击