![](https://iknow-base.cdn.bcebos.com/lxb/notice.png)
这段C++代码为什么输出乱码?(关于字符串处理)
#include<iostream>#include<string>usingnamespacestd;char*func(char*a);intmain(){print...
#include <iostream>
#include <string>
using namespace std;
char* func( char* a );
int main()
{
printf("abc,123,efg,456\n");
printf("%s\n", func("abc,123,efg,456"));
cout<<func("abc,123,efg,456")<<endl;
system("pause");
return 0;
}
char* func( char* a )
{
char p[50];
memset( p, 0, 50*sizeof(char) );
strcpy(p, a);
return p;
}
我在return p; 设置过断点,复制字符串没问题,但输出的是乱码。请教为什么? 展开
#include <string>
using namespace std;
char* func( char* a );
int main()
{
printf("abc,123,efg,456\n");
printf("%s\n", func("abc,123,efg,456"));
cout<<func("abc,123,efg,456")<<endl;
system("pause");
return 0;
}
char* func( char* a )
{
char p[50];
memset( p, 0, 50*sizeof(char) );
strcpy(p, a);
return p;
}
我在return p; 设置过断点,复制字符串没问题,但输出的是乱码。请教为什么? 展开
2个回答
展开全部
因为p数组是在函数func内部声明的,而当函数结束之后,函数内部生命的变量所占内存就会被系统回收,这样p的内容就不确定了。
改成下面就ok了~
char* func( char* a )
{
char* p=new char[50];
memset( p, 0, 50*sizeof(char) );
strcpy(p, a);
return p;
}
不过说,这样的代码会造成内存泄漏,所以改用string类就会完全避免这样的问题~
其实最正确的写法就是new然后返回char*,然后在其他函数调用的时候,用完delete掉相应的内存
望采纳~
改成下面就ok了~
char* func( char* a )
{
char* p=new char[50];
memset( p, 0, 50*sizeof(char) );
strcpy(p, a);
return p;
}
不过说,这样的代码会造成内存泄漏,所以改用string类就会完全避免这样的问题~
其实最正确的写法就是new然后返回char*,然后在其他函数调用的时候,用完delete掉相应的内存
望采纳~
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询