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)指针操作超越了变量的作用范围