指针做为形参

1,


void GetMemory(char *p, int num)
{
    p = (char *)malloc(sizeof(char) * num);
}

void Test(void)
{
	char *str = NULL;
	GetMemory(str, 100);    // str 仍然为 NULL 
	strcpy(str, "hello");   // 运行错误
}

  


原因:编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是 _p,编译器使 _p = p。如果函数体内的程序修改了_p的内容,就导致参数p的内容作相应的修改。这就是指针可以用作输出参数的原因。在本例中,_p申请了新的内存,只是把_p所指的内存地址改变了,但是p丝毫未变。所以函数GetMemory并不能输出任何东西。事实上,每执行一次GetMemory就会泄露一块内存,因为没有用free释放内存。

 

只修改了临时副本_p的内容,但p的内容没有修改

2:

void GetMemory2(char **p, int num)
{
	*p = (char *)malloc(sizeof(char) * num);
}
void Test2(void)
{
	char *str = NULL;
	GetMemory2(&str, 100);  // 注意参数是 &str,而不是str
	strcpy(str, "hello");  
	cout<< str << endl;
	free(str); 
}

  


3:指针的指针不好理解,可以用返回值传递

char *GetMemory3(int num)
{
    char *p = (char *)malloc(sizeof(char) * num);
    return p;
}

  

4:动态内存会被自动释放掉么

(1)指针消亡了,不代表它所指的内存被自动释放

(2)内存被释放了,并不表示指针会消亡或者成了NULL指针了

5:产生野指针的原因:

1)指针没初始化,2)指针p,free或者delete后,p没有设置为NULL,仍然被认为是个合法的指针使用,3)指针操作超越了变量的作用范围

 

 

posted @ 2012-04-23 22:35  foreverlearn  阅读(445)  评论(0编辑  收藏  举报