string 与char* char[]之间的转换

     和char* 不同的是,string不一定以NULL(‘\0’)结束,string长度可以根据length()得到,string可以根据下标进行访问。所以,不能将string直接复制给char*

一、首先必须了解,string可以被看成是以字符为元素的一种容器。字符构成序列(字符串)。标准string类提供了STL容器接口。

具有一些成员函数比如begin()、end(),迭代器可以根据他们进行定位。

    注:不能那个string直接赋值给char*。

二、 string转换成char*

   用.c_str()

  string s = "abcd";

const char * c =s.c_str();

如上,都可以输出。内容是一样的。但是只能转换成const char*,如果去掉const编译不能通过

如果要转换成char*,可以用string的一个成员函数copy实现。

string s ="abc";
char* c;
constint len = s.length();
c =newchar[len+1];
strcpy(c,s.c_str());

或者

string s1 = "abcdefg";
char *data;
int len = s1.length();
data = (char *)malloc((len+1)*sizeof(char));
s1.copy(data,len,0);
printf("%s",data);
cout<<data;


三、char*转换成string

可以直接赋值;

string s;

char *p = "adghrtyh";

s = p;

不过这个是会出现问题的。

有一种情况我要说明一下。当我们定义了一个string类型之后,用printf("%s",s1);输出是会出问题的。这是因为“%s”要求后面的对象的首地址。但是string不是这样的一个类型。所以肯定出错。

用cout输出是没有问题的,若一定要printf输出。那么可以这样:
printf("%s",s1.c_str())

四、char【】转换成string

 这个可以直接赋值,但是也会出现上面的问题。需要同样的处理

五、string转换成char[]

这个由于我们知道string的长度,可以根据length()函数得到,又可以根据下标直接访问,所以用一个循环就可以赋值了。

这样的转换不可直接赋值。

    string pp = "dagah";
    char p[8];
    int i;
    for( i=0;i<pp.length();i++)
        p[i] = pp[i];
    p[i] = '\0';
    printf("%s\n",p);
    cout<<p;

六、我是这么认为的:

      char* str 是静态的;
     char temp[]是动态的 

    指针不占空间,在使用前必须对他进行初始化,但后面的会分配空间

要用const_cast()来处理




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值