第4章 指针和数组
一.一级指针参数
1.能否把指针变量本身传给一个函数
例:
void fun(char *p)
{
char c= p[3];
}
int main()
{
char *p2= "abcdefg";
fun(p2);
retrun 0;
}
这个函数调用真的把p2本身传递到了fun函数内部吗?
解析:p2是main函数内的一个局部变量,它只在main函数内部有效。既然它是内部函数,fun函数肯定无法使用p2的真身。那函数调用怎么办?好办:对实参做一份备份并传递给被调用函数,即对p2做一份备份,假设其设备名为_p2,那么传递到函数内部的就是_p2而非p2本身。
2.无法把指针变量本身传递给一个函数
fun函数实际运行时,用到的都是_p2这个变量而非p2本身。
void GetMemory(char *p ,int num)
{
p = (char *) malloc(num *sizeof(char));
}
int main()
{
char *str =NULL;
GetMemory(str ,10);
strcpy(str, "hello");
free(str);
return 0;
}
在运行strcpy(str, "hello")语句的时候发生错误。这时候观察str的值,发现仍然为NULL.也就是说str本身并没有改变,我们malloc的内存的地址并没有赋给str,而是赋给了_str。而这个_str是编译器自动分配和回收的,我们根本就无法使用,所以想这样获取一块内存是不行的。
2个解决办法:
(1).用retrun
void GetMemory(char *p ,int num)
{
p = (char *) malloc(num *sizeof(char));
return p;
}
int main()
{
char *str =NULL;
GetMemory(str ,10);
strcpy(str, "hello");
free(str);
return 0;
}
(2)用二级指针
void GetMemory(char *p ,int num)
{
p = (char *) malloc(num *sizeof(char));
}
int main()
{
char *str =NULL;
GetMemory(&str ,10);
strcpy(str, "hello");
free(str);
return 0;
}
注意,这里的参数是&str而非str,这样的话传递过去的是str的地址,是一个值。在函数内部,用钥匙(“*”)来开锁:*(&str)其值就是str。所以malloc分配的内存地址是真正赋值给了str本身。
指针与内存分配
本文探讨了一级指针参数在C/C++中的使用限制,并通过具体示例解释了为何不能直接将指针变量本身传递给函数。同时介绍了两种解决方法:通过返回值或使用二级指针来实现内存的有效分配。
953

被折叠的 条评论
为什么被折叠?



