面试题

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

题目一:

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

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值