_ | 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博主「白夜行的狼」的原创文章链接
网友评论