Chinaunix首页 | 论坛 | 博客
  • 博客访问: 57937
  • 博文数量: 32
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 255
  • 用 户 组: 普通用户
  • 注册时间: 2016-12-02 09:11
文章分类

全部博文(32)

文章存档

2017年(21)

2016年(11)

我的朋友

分类: C/C++

2017-01-11 13:08:45

1、首先必须了解,string可以被看成是以字符为元素的一种容器。字符构成序列(字符串)。有时候在字符序列中进行遍历,标准的string类提供了STL容器接口。具有一些成员函数比如begin()、end(),迭代器可以根据他们进行定位。

注意,与char*不同的是,string不一定以NULL('\0')结束。string长度可以根据length()得到,string可以根据下标访问。所以,不能将string直接赋值给char*。

2、string 转换成 char *

如果要将string直接转换成const char *类型。string有2个函数可以运用。

一个是.c_str(),一个是data成员函数。

例子如下:
  1. string s1 = "abcdeg";
  2. const char *k = s1.c_str();
  3. const char *t = s1.data();
  4. printf("%s%s",k,t);
  5. cout<<k<<t<<endl;

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

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


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

3、char *转换成string

可以直接赋值。

  1. string s;
  2. char *p = "adghrtyh";
  3. s = p;

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

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

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


4、char[] 转换成string

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


5、string转换成char[]

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

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

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

阅读(548) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~