源码:
char szImgPath[1000];
string loadImgPath;
//string to char*
sprintf( szImgPath, "%s.jpg", loadImgPath );
//char* to string
loadImgPath = szImgPath;
该代码编译到sprintf时会提示以下错误:
不能通过‘...’传递有不能平凡复制的类型‘const string {aka const class std::basic_string<char>}’
要将该句改为:
sprintf( szImgPath, "%s.jpg", loadImgPath.c_str() );
或者:
sprintf( szImgPath, "%s.jpg", loadImgPath.data() );
原因分析:
(1)string to char*
string可以被看成是以字符为元素的一种容器,字符构成序列(字符串)。有时候在字符序列中进行遍历,标准的string类提供了STL容器接口。具有一些成员函数比如begin()、end(),迭代器可以根据他们进行定位。
与char*不同的是,string不一定以NULL('\0')结束。
string长度可以根据length()得到,string可以根据下标访问。所以,不能将string直接赋值给char*。
要将string转换成const char *类型,有2个函数可以运用:一个是.c_str(),一个是data成员函数。但是只能转换成const char*,如果去掉const编译不能通过。
如果要将string转换成char*,可以用string的成员函数copy实现,如下:
string s1 = "abcdefg";
char *data;
int len = s1.length();
data = (char *)malloc((len+1)*sizeof(char));
s1.copy(data,len,0);
(2)char* to string
char*转换到string是可以直接赋值的;
但是当我们定义了一个string类型的s1变量之后,用
<span style="font-size:12px;">printf("%s",s1);</span>
输出是会出问题的,因为“%s”要求后面的对象的首地址,但是string不是这样的一个类型。
若一定要用printf输出,可以改为:
printf("%s",s1.c_str());
(3)char[] to string
可以直接赋值。 但是也会出现上面的问题。需要同样的处理。
(4)string to char[]
可以使用length()函数得到string的长度,再根据下标直接访问,用循环赋值,如下:
string pp = "dagah";
char p[8];
int i;
for( i=0;i<pp.length();i++)
p[i] = pp[i];
p[i] = '\0';
但是不可以直接赋值。
参考:http://www.aichengxu.com/view/48568