谁给说说这几个函数的内存问题到底是怎么回事。。。
题目一:
void GetMemory( char *p) { p = (char *) malloc( 100 ); } void Test(void) { char *str=NULL; GetMemory(str); strcpy( str, "hello world" ); puts(str); }调用GetMemory(); 函数的时候,把str指针赋值给了指针p,然后在函数内部,动态申请了一个空间,让指针p指向了这块空间,但是str并没有指向这块空间,GetMemory函数内部操作的是指针p,并不是指针str,所以调用strcpy函数将hello world 拷贝到str指向的空间的时候,发生了内存访问失败的问题。调用函数GetMemory的时候,指针str赋值给了指针p,这是,指针p跟指针str指向同一个地方;GetMemory函数内部,修改了指针p的指向,使其指向了一块动态开辟的空间,而指针str并没有指向新开辟的空间。因为str只是一个指针,并没有指向内存空间,所以strcpy的拷贝功能失败,程序无法运行。。。
可以将指针str的引用传给指针p,这样GetMemory函数内部的对指针p的操作就等价于对指针str的操作。
void GetMemory( char *&p) //对指针的引用,函数内部对指针p的修改就等价于对指针str的修改 { p = (char *) malloc( 100 ); } void Test(void) { char *str=NULL; GetMemory(str); strcpy( str, "hello world" ); puts(str); }题目二:
char *GetMemory( void ) { char p[] = "hello world"; return p; } void Test( void ) { char *str = NULL; str = GetMemory(); puts( str ); }p数组是在函数内部临时声明的,属于栈上的临时变量,函数结束后就销毁了。GetMemory函数返回后,将那个p数组销毁了,里面的内容自然就没有了,只是返回了数组的首地址给str指针,此时str就是一个野指针,每次输出的内容都不一样的。。
修改为下面的代码就可以正确输出hello world了,这就是上一篇文章中讲的------char *str和char str[]的区别了。。
或者将p数组声明为static 类型的也是可以正确输出hello world 的。。
char *GetMemory( void ) { static char p[] = "hello world"; return p; } void Test( void ) { char *str = NULL; str = GetMemory(); puts(str); }题目三:
void GetMemory( char **p, int num ) //**p指向指针str的地址,也就是说**p==&str { *p = (char *)malloc(num); //*p指针就是str指针,也就是说,*p==str,这行代码实际上改变的是str指针的指向,指向了一块申请的内存空间 } void Test( void ) { char *str = NULL; GetMemory(&str,100); strcpy(str, "hello world"); puts(str); }使用的是指针的指针的理论,这个是可以正确输出hello world 的。。
题目四:
这个是可以正确输出hello world 的。。
题目五:写出运行结果
输出的结果为 6:4:1:4