由于这两天恰好用到char *和string之间的转换,在网上搜索各种方法,在这里记录一下,以便日后翻阅.
参考:
和https://zhidao.baidu.com/question/104592558.html
char * 或者char[]转换成string
方法:直接赋值
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str ;
const char *p = "hello";
char tmp[] = "world";
str = p;
str += tmp;
cout << str << endl;
//printf出错,这是因为“%s”要求后面的对象的首地址。
//但是string不是这样的一个类型。所以肯定出错。
//printf("%s",str);
return 0;
}
string转换成 char * 或者char[]
方法一(最常用,推荐): string类的c_str()函数
- 最好不要这样
string str = "hello";
char *p;
p = str.c_str(); //p最后指向的内容是垃圾,因为str对象被析构,其内容被处理
- 正确做法,使用strcpy,在c++里为了安全性使用strcpy_s,包含在头文件
<cstring>
里面。
string str = "hello";
char p[20];
strcpy_s(p, str.c_str());
return 0;
- 或者
//这一段在cppreference里面在线编译运行的,
//用的VS2017的编译器不支持strcpy,
//而且不支持strcpy_s里面的参数类型为(char *,const char*)
//说没有匹配的重载函数
string str = "hello";
char *p;
p = (char *)malloc((str.length()+1)*sizeof(char));
strcpy(p, str.c_str());
经过百度发现strcpy_s
的原型为strcpy_s( char *strDestination, size_t numberOfElements, const char *strSource );第二个参数是strDestination字符串的大小,用意是控制复制的字符数,最多复制numberofelements个字符。
string str = "hello";
char *p;
p = (char *)malloc((str.length()+1)*sizeof(char));
strcpy_s(p, str.length() + 1, str.c_str());
//c_str()返回一个以‘\0’结尾的字符数组,不用手动添加结束符
而上面当p声明为数组类型的时候,strcpy_s又可以接受两个函数,原因从这段文字可以找出 “strcpy函数,就象gets函数一样,它没有方法来保证有效的缓冲区尺寸,所以它只能假定缓冲足够大来容纳要拷贝的字符串。在程序运行时,这将导致不可预料的行为。用strcpy_s就可以避免这些不可预料的行为。这个函数用两个参数、三个参数都可以,只要可以保证缓冲区大小。”
p.s. 如果一个函数要求char*参数,可以使用c_str()方法:
string s = "Hello World!";
printf("%s", s.c_str()); //输出 "Hello World!"
方法二: string类的copy函数
//vs2017会报copy函数可能不安全错误,错误代码C4996
//解决方法是在项目属性里面设置略过这个错误,即属性-->通用配置
//-->c/c++-->预处理器里面加上_SCL_SECURE_NO_WARNINGS
string str = "hello";
char *p;
int len = str.length();
p = (char *)malloc((len + 1) * sizeof(char));
str.copy(p, str.length(), 0);
p[len] = '\0'; //注意要让最后一位为字符串结尾的标记符‘\0’
方法三: string类的data函数
用法基本和c_Str()函数一样
string str = "hello";
char *p;
p = (char *)malloc((str.length() + 1) * sizeof(char));
strcpy_s(p, str.length()+1, str.data());
p.s.
1. data只是返回原始数据序列,没有保证会用traits::eos(),或者说’\0’来作字符串结束. 当然,可能多数实现都这样做了。
c_str是标准的做法,返回的char* 一定指向一个合法的用’\0’终止的C兼容的字符串。
所以,如果需要C兼容的字符串,c_str 是标准的做法,data 并不保证所有STL的实现的一致性。
2. strcpy 是C语言标准库函数strcpy,把从src地址开始且含有’\0’结束符的字符串复制 到 以dest开始的地址空间。