美文网首页
C++ 处理字符串

C++ 处理字符串

作者: 黑小柴 | 来源:发表于2020-01-29 20:30 被阅读0次
    _ string char* , char[]
    头文件 #include<string> none
    初始化 string s1("abc");
    string s2(s1);
    string s3(4, 's');//初始化为4个's'
    const char * a = "test";//数据存在静态存储区,不能修改
    char a[] = "test";//开辟数组再存储,可以修改
    char* a = new char[10];
    memset(a, '0', sizeof(char)*10);
    转化 char* p = "hello";
    string s(p);
    s = p;
    string str("test");
    const char* p = str.data();//记得要加const或者强制类型转换成(char)
    const char
    p = str.c_str();
    char p[10];
    std::size_t length = str.copy(p,5,0);//从第0个开始复制5个,返回有效复制的数量,需要在p最后添加'\0'
    char * cstr = new char [str.length()+1];
    std::strcpy (cstr, str.c_str());
    或逐个复制
    大小 str.size()
    str.length()
    std::strlen(p)
    容器大小 str.capacity() 数组形式p[],可以使用sizeof(p)来获得数组大小
    指针形式没有容器概念,除非是new的,对指针用sizeof将得到指针本身的大小,由系统位数决定
    倒置 #include <algorithm>
    std::reverse(str.begin(),str.end());
    char* strrev(char* s);
    查找 find//从头开始找
    rfind//从尾开始找
    这四个函数都有四种重载:
    size_t find (const string& str, size_t pos = 0);//查找子string,默认从父string的第0个字符开始,如果要查找多个相似的,则可以将pos设置为上次查找到的+1
    size_t find (const char* s, size_t pos = 0);//查找字符串,默认从0开始
    size_t find (const char* s, size_t pos, size_type n);//同上,但只比较n个
    size_t find (char c, size_t pos = 0);//比较字符。
    当然,形参初始化的值可能不一样,返回的都是地址索引,需要通过found!=std::string::npos判断是否有效。
    find_first_of
    find_last_of
    find_first_not_of
    find_last_not_of
    也有上面四种重载,不过这里是返回第一个出现、没有出现在子str的字符的索引。

    std::string str ("look for non-alphabetic characters...");
    std::size_t found = str.find_first_not_of("abcdefghijklmnopqrstuvwxyz ");
    char* strchr(char* s, char c);//查找字符串s中首次出现字符c的位置,返回c位置的指针,如不存在返回NULL
    char * strrchr(const char *str, int c);//查找字符倒数第一次出现的位置
    char *strstr(const char *s1,const char *s2);//查找第一次出现s2的位置,返回s2的位置指针,如不存在返回NULL
    char *strrstr(const char *s1,const char *s2);//查找倒数第一个出现s2的位置
    int strspn(const char *s,const char *accept);//作用同右侧find_first_not_of。返回s中第一个没有在accept出现的字符的索引。通过两个for循环来实现
    int strcspn(const char *s,const char *reject);//s中第一个在reject出现的字符的索引。
    大小写转换 两者都是不提供这个功能的,但是C++有两个库函数,头文件是#include <ctype.h>:
    int tolower ( int c );
    int toupper ( int c );
    实现也很简单:
    int tolower(int c)
    {
    if ((c >= 'A') && (c <= 'Z'))
    return c + ('a' - 'A');
    return c;
    }

    转自CSDN博主「白夜行的狼」的原创文章链接

    相关文章

      网友评论

          本文标题:C++ 处理字符串

          本文链接:https://www.haomeiwen.com/subject/mnlbthtx.html