GetMemory函数详解

来源:互联网 发布:电视剧国防生知乎 编辑:程序博客网 时间:2024/05/30 23:22

void GetMemory(char *p)

{

      p=(char *)malloc(100);

}

void Test()

{

  char *str=NULL;

 GetMemory(str);

  strcpy(str,"Helloworld");

 printf(str);

}

 

实质:GetMemory(str)在调用时会生成一个_str与str指向同一个数,这是因为C语言中函数传递形参不改变实参的内容,但是指针指向的内容是相同的,因此可以用指针控制数据。题中的GetMemory(str),实质是对_str的操作,并没有对str操作,函数结束后_str撤销,因此不会产生新的内存空间,str仍然是一个空指针。


要在函数内部改变某个变量的值,使之能在出了这个函数后,刚才的改变仍然有效,那就必须通过参数传入“指向这个变量的指针”,而不是变量本身。也就是说,任何函数都不能把对参数本身的改变带到函数体外,所改的只是这个参数所指向的变量的值。

[cpp] view plain copy
  1. void func1(char *p)  
  2. {  
  3.     *p = 1; //这是改变p指向的变量的值,可以  
  4.     p = 2; //这是改变p本身,不可以。p本身也是一个变量(指针变量),和它指向的变量是两个不同的概念。它是参数,是个局部变量,出了函数体后就销毁了。  
  5. }  
  6.   
  7. int main()  
  8. {  
  9.     char ch;  
  10.     char *p = ch;  //p指向ch这个变量,那么通过func1函数后,修改的是p指向的变量即ch的值,不是p本身的值!  
  11.   
  12.     func1(p);  
  13.     return 0;  
  14. }  

[cpp] view plain copy
  1. void func2(char **p)  
  2. {  
  3.     *p = (char*)malloc(16);   
  4. }  
  5.   
  6. int main()  
  7. {  
  8.     char *p;  
  9.     char **p1 = &p;  //p1指向p这个变量(指针变量),那么通过func2函数后,修改的是p1指向的变量即p的值,不是p1本身的值!  
  10.   
  11.     func2(p1);  
  12.     return 0;  
  13. }  



 

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语句永远不能被执行(注:strcpy(str,"World")有风险),这也是著名的“野”指针问题。

 

NO6

void GetMemory(void)

{

      char *str=(char *)malloc(100);

      strcpy(str,"hello");

      free(str);

      if (str !=NULL)

      {

             strcpy(str,"world");

             printf(str);

      }

}

Str 为野指针,打印的结果不能确定。

原创粉丝点击