zoukankan      html  css  js  c++  java
  • C++ string和char char*的转换

    c++string 是个字符串类,可以看做是一个字符容器。
    其有成员函数,比如.size() ,  .length()等等,
    详见 http://www.cnblogs.com/xFreedom/archive/2011/05/16/2048037.html
    另外:string 不一定以‘’结尾
    详见 http://blog.csdn.net/qq_31779399/article/details/51520603
    1 string->char*
    如果要将string直接转换成const char *类型。string有2个函数可以运用。
    一个是.c_str(),一个是data成员函数。
    例子如下:
    string s1 = "abcdeg";
    const char *k = s1.c_str();
    const char *t = s1.data();
    printf("%s%s",k,t);
    cout<<k<<t<<endl;

    如上,都可以输出。内容是一样的。但是只能转换成const char*,如果去掉const编译不能通过,因为string是const char*类型。
    那么,如果要转换成char*,可以用string的一个成员函数copy实现。


    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;

    2 char *->string
    可以直接赋值。
    char *p = "adghrtyh";

    string s; 

    s = p;

    或string s(p);//因为string有构造函数  string(const char *s);    //用c字符串s初始化


    3 char[] ->string

    同2


    4 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] = '';
    printf("%s ",p);
    cout<<p;

  • 相关阅读:
    剑指Offer34 数组中的逆序对
    剑指Offer33 第一个只出现一次的字符
    剑指Offer32 丑数
    剑指Offer31 把数组排成最小的数
    剑指Offer30 从1到n整数出现1的个数
    剑指Offer29 连续子数组最大和
    剑指Offer28 最小的K个数(Partition函数应用+大顶堆)
    DNS的递归查询和迭代查询
    剑指Offer27 数组中超过一半的数
    剑指Offer26 字符串的全排列
  • 原文地址:https://www.cnblogs.com/zhubaohua-bupt/p/7182796.html
Copyright © 2011-2022 走看看