c/c++ 调用子函数内存分配

摘自 : http://blogread.cn/it/article/1266?f=sa

void GetMemory(char *p)
{
   p=(char*)malloc(100);
}

void Test(void)
{
   char *str = NULL;
   GetMemory(str);
   strcpy(str,”helloworld”);
   printf(str);
}

 

请问运行Test函数会有什么样的结果?
答:程序崩溃。因为GetMemory并不能传递动态内存,Test函数中的str一直都是NULL。strcpy(str,”helloworld”);将使程序崩溃。

子函数开辟空间p,用于指向申请的地址,且没有返回值,此函数结束,p将被收回,内存出现泄漏。

在c++中两种传参方式,这属于第一种-值传递。在函数内部对形参p的操作,在函数返回时并不会影响实参str的值。另外在函数内部动态分配内存,导致内存泄露。此题应该将函数参数改为引用类型。指针的引用。在调用结束要释放内存。

 

char *GetMemory(void)
{
  char p[]=”helloworld”;
  return p;
}
void Test(void)
{
  char *str = NULL;
  str = GetMemory();
  printf(str);
}

 

 

请问运行Test函数会有什么样的结果?
答:可能是乱码。因为GetMemory返回的是指向“栈内存”的指针,该指针的地址不是NULL,但其原先的内容已经被清除,新内容不可知。

 调用函数时会分配栈给函数时候,调用结束后,这块空间的地址返回,给了str,但是这块空间里面的内容可能被别的程序改了。

返回指向局部变量的指针是c++中的大忌。在函数中,char p[]=”helloworld”; p属于GetMemory函数中的局部变量。在栈空间上分配的内存,但是函数返回后,在栈空间上的局部变量内存被释放,这时候返回p的指向内存给str,虽然str有指向,但是str指向的内存已被释放,属于野指针。

void GetMemory2(char **p, int num)
{
   *p = (char*)malloc(num);
}
void Test(void)
{
   char *str = NULL;
   GetMemory(&str, 100);
   strcpy(str, “hello”);
   printf(str);
}

 

请问运行Test函数会有什么样的结果?
答:(1)能够输出hello(2)内存泄漏

传递指针的指针和传递指针的引用有相同的功效。这时候对形参的改变会影响实参的值。str会指向在GetMemory2函数中动态分配的内存。由于这里分配用的是malloc函数,申请的内存是在堆空间,要由程序员自己用free去释放,在函数返回时,空间不会被收回。但是这里没有主动去释放堆空间,泄露。

函数调用的时候,函数创建了一个二级指针,p指向了str的地址,*p=str里的值,**p是str指向的值,然后malloc给*p,就是改变了str里面的值,所以str指的地址就发生了改变,所以就可以用了。

转载于:https://www.cnblogs.com/stewarttzy/archive/2013/05/21/3091069.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值