面试题

 谁给说说这几个函数的内存问题到底是怎么回事。。。

题目一:

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[]的区别了。。

char *GetMemory( void ) { char *p = "hello world"; return p; } void Test( void ) { char *str = NULL; str = GetMemory(); puts(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 的。。
题目四:

void Test( void ) { char *str = (char *) malloc(100); strcpy( str, "hello world" ); puts(str); free( str ); }

这个是可以正确输出hello world 的。。

题目五:写出运行结果

#include "iostream" using namespace std; int main(void) { char str[] = "world"; cout << sizeof(str) << ": "; char *p = str; cout << sizeof(p) << ": "; char i = 10; cout << sizeof(i) << ": "; void *pp = malloc(10); cout << sizeof(pp) << endl; system("pause"); return 0; }

输出的结果为 6:4:1:4

转载于:https://www.cnblogs.com/newthing/archive/2011/08/23/2157459.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值