C++字符知识点总结

一、sting类的输入输出

  1. cin>>str,cout<<str ,string类重载运算符;
  2. getline(istream &in,string &s), 用于从输入流in中读取字符串到s中,以换行符’\n’分开。如,getline(cin,str);
    cin遇到空格会停止,所以如果要输入含空格的字符串,要用getline

cin
• 接受一个字符串,遇“空格”、“Tab”、“回车”都结束
• #include
• using namespace std;
• main()
• {
• char a[20];
• cin >> a;
• cout << a << endl;
• }

• 输入:ab cd //遇空格结束,所以不能输入多个单词
• 输出:ab

cin.get()
用法一:cin.get(字符变量名)可以用来接收字符
#include
using namespace std;
int main()
{
char ch;
ch = cin.get(); //或者cin.get(ch);只能获取一个字符
cout << ch << endl;
}

输入:abc
输出:a

用法二:cin.get(字符数组名,接收字符数)用来接收一行字符串,可以接收空格
#include
using namespace std;
int main()
{
char a[10];
cin.get(a, 10); //有些类似getline。可以输入多个单词,中间空格隔开。
cout << a << endl;
}

输入:abc abc
输出:abc abc

输入:abcdeabcdeabcde(输入15个字符)
输出:abcdeabcd (接收9个字符+1个’\0’)

用法三:cin.get(无参数)没有参数主要是用于舍弃输入流中的不需要的字符,或者舍弃回车,弥补cin.get(字符数组名,接收字符数目)的不足。
#include
using namespace std;
int main(void)
{
char arr[10];
cin.get(arr, 10);
cin.get(); //用于吃掉回车,相当于getchar();
cout << arr << endl;
cin.get(arr, 5);
cout << arr << endl;
return 0;
}

输入abcdefghi
输出abcdefghi
输入abcde
输出abcd
请按任意键继续

cin.getline()
cin.getline() ----接受一个字符串,可以接收空格并输出
#include
using namespace std;
int main ()
{
char m[20];
cin.getline(m,5); //与上面基本相同。
cout<<m<<endl;
}

输入:jkljkljkl
输出:jklj
接受5个字符到m中,其中最后一个为’\0’,所以只看到4个字符输出;

如果把5改成20:
输入:jkljkljkl
输出:jkljkljkl

输入:jklf fjlsjf fjsdklf
输出:jklf fjlsjf fjsdklf
//延伸:
//cin.getline()实际上有三个参数,cin.getline(接受字符串到m,接受个数5,结束字符)
//当第三个参数省略时,系统默认为’\0’ 是‘/n’吧。
//如果将例子中cin.getline()改为cin.getline(m,5,‘a’);当输入jlkjkljkl时输出jklj,输入jkaljkljkl时,输出jk

getline()
getline() // 接受一个字符串,可以接收空格并输出,需包含“#include”
#include
#include
using namespace std;
int main()
{
string str;
getline(cin, str);
cout << str << endl;
return 0;
}

输入:jkljkljkl //VC6中有个bug,需要输入两次回车。
输出:jkljkljkl

输入:jkl jfksldfj jklsjfl
输出:jkl jfksldfj jklsjfl

和cin.getline()类似,但是cin.getline()属于istream流,而getline()属于string流,是不一样的两个函数
gets()
gets()// 接受一个字符串,可以接收空格并输出,需包含“#include
#include
#include
using namespace std;
int main()
{
char m[20];
gets(m); //不能写成m=gets();
cout << m << endl;
return 0;
}
输入:jkljkljkl
输出:jkljkljkl

输入:jkl jkl jkl
输出:jkl jkl jkl

getchar()
getchar()//接受一个字符
#include
using namespace std;
int main()
{
char ch;
ch = getchar(); //不能写成getchar(ch);
cout << ch << endl;
return 0;
}

输入:jkljkljkl
输出:j

//getchar()是C语言的函数,C++也可以兼容,但是尽量不用或少用

1)字符串操作
strcpy(p, p1) 复制字符串
strncpy(p, p1, n) 复制指定长度字符串
strcat(p, p1) 附加字符串
strncat(p, p1, n) 附加指定长度字符串
strlen§ 取字符串长度
strcmp(p, p1) 比较字符串
strcasecmp忽略大小写比较字符串
strncmp(p, p1, n) 比较指定长度字符串
strchr(p, c) 在字符串中查找指定字符
strrchr(p, c) 在字符串中反向查找
strstr(p, p1) 查找字符串
strpbrk(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找该集合的任一元素
strspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找不属于该集合的任一元素的偏移
strcspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找属于该集合的任一元素的偏移

  • 具有指定长度的字符串处理函数在已处理的字符串之后填补零结尾符

2)字符串到数值类型的转换
strtod(p, ppend) 从字符串 p 中转换 double 类型数值,并将后续的字符串指针存储到 ppend 指向的 char* 类型存储。
strtol(p, ppend, base) 从字符串 p 中转换 long 类型整型数值,base 显式设置转换的整型进制,设置为 0 以根据特定格式判断所用进制,0x, 0X 前缀以解释为十六进制格式整型,0 前缀以解释为八进制格式整型
atoi§ 字符串转换到 int 整型
atof§ 字符串转换到 double 符点数
atol§ 字符串转换到 long 整型

3)字符检查
isalpha() 检查是否为字母字符
isupper() 检查是否为大写字母字符
islower() 检查是否为小写字母字符
isdigit() 检查是否为数字
isxdigit() 检查是否为十六进制数字表示的有效字符
isspace() 检查是否为空格类型字符
iscntrl() 检查是否为控制字符
ispunct() 检查是否为标点符号
isalnum() 检查是否为字母和数字
isprint() 检查是否是可打印字符
isgraph() 检查是否是图形字符,等效于 isalnum() | ispunct()

4)函数原型
原型:strcpy(char destination[], const char source[]);
功能:将字符串source拷贝到字符串destination中
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
  char str1[10] = { “TsinghuaOK”};
  char str2[10] = { “Computer”};
  cout <<strcpy(str1,str2)<<endl;
}
运行结果是:Computer
第二个字符串将覆盖掉第一个字符串的所有内容!
注意:在定义数组时,字符数组1的字符串长度必须大于或等于字符串2的字符串长度。不能用赋值语句将一个字符串常量或字符数组直接赋给一个字符数组。所有字符串处理函数都包含在头文件string.h中。

strncpy(char destination[], const char source[], int numchars);
strncpy:将字符串source中前numchars个字符拷贝到字符串destination中。
strncpy函数应用举例
原型:strncpy(char destination[], const char source[], int numchars);
功能:将字符串source中前numchars个字符拷贝到字符串destination中
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
  char str1[10] = { "Tsinghua "};
  char str2[10] = { “Computer”};
  cout <<strncpy(str1,str2,3)<<endl;
}
运行结果:Comnghua
注意:字符串source中前numchars个字符将覆盖掉字符串destination中前numchars个字符!

原型:strcat(char target[], const char source[]);
功能:将字符串source接到字符串target的后面
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
  char str1[] = { "Tsinghua "};
  char str2[] = { “Computer”};
  cout <<strcpy(str1,str2)<<endl;
}
运行结果:Tsinghua Computer
注意:在定义字符数组1的长度时应该考虑字符数组2的长度,因为连接后新字符串的长度为两个字符串长度之和。进行字符串连接后,字符串1的结尾符将自动被去掉,在结尾串末尾保留新字符串后面一个结尾符。

原型:strncat(char target[], const char source[], int numchars);
功能:将字符串source的前numchars个字符接到字符串target的后面
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
  char str1[] = { "Tsinghua "};
  char str2[] = { “Computer”};
  cout <<strncat(str1,str2,3)<<endl;
}
运行结果:Tsinghua Com

原型:int strcmp(const char firststring[], const char secondstring);
功能:比较两个字符串firststring和secondstring
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
  char buf1[] = “aaa”;
  char buf2[] = “bbb”;
  char buf3[] = “ccc”;
  int ptr;
  ptr = strcmp(buf2,buf1);
  if(ptr > 0)
   cout <<“Buffer 2 is greater than buffer 1”<<endl;
  else
   cout <<“Buffer 2 is less than buffer 1”<<endl;
  ptr = strcmp(buf2,buf3);
  if(ptr > 0)
   cout <<“Buffer 2 is greater than buffer 3”<<endl;
  else
   cout <<“Buffer 2 is less than buffer 3”<<endl;
}
运行结果是:Buffer 2 is less than buffer 1
Buffer 2 is greater than buffer 3

原型:strlen( const char string[] );
功能:统计字符串string中字符的个数
例程:
#include <iostream.h>
#include <string.h>
void main(void)
{
char str[100];
cout <<“请输入一个字符串:”;
cin >>str;
cout <<“The length of the string is :”<<strlen(str)<<“个”<<endl;
}
运行结果The length of the string is x (x为你输入的字符总数字)
注意:strlen函数的功能是计算字符串的实际长度,不包括’\0’在内。另外,strlen函数也可以直接测试字符串常量的长度,如:strlen(“Welcome”)。

void *memset(void *dest, int c, size_t count);
将dest前面count个字符置为字符c. 返回dest的值.
Memset 用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’;
例:char a[100];memset(a, ‘/0’, sizeof(a));
memset可以方便的清空一个结构类型的变量或数组。
如:
struct sample_struct
{
char csName[16];
int iSeq;
int iType;
};

对于变量:
struct sample_strcut stTest;
一般情况下,清空stTest的方法:
stTest.csName[0]=’/0’;
stTest.iSeq=0;
stTest.iType=0;
用memset就非常方便:
memset(&stTest,0,sizeof(struct sample_struct));

如果是数组:
struct sample_struct TEST[10];

memset(TEST,0,sizeof(struct sample_struct)*10);

void *memmove(void *dest, const void *src, size_t count);
从src复制count字节的字符到dest. 如果src和dest出现重叠, 函数会自动处理. 返回dest的值.

void *memcpy(void *dest, const void *src, size_t count);
从src复制count字节的字符到dest. 与memmove功能一样, 只是不能处理src和dest出现重叠. 返回dest的值.
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度。
例:char a[100],b[50]; memcpy(b, a, sizeof(b));注意如用sizeof(a),会造成b的内存地址溢出。
Strcpy 就只能拷贝字符串了,它遇到’/0’就结束拷贝

void *memchr(const void *buf, int c, size_t count);
在buf前面count字节中查找首次出现字符c的位置. 找到了字符c或者已经搜寻了count个字节, 查找即停止. 操作成功则返回buf中首次出现c的位置指针, 否则返回NULL.

void *_memccpy(void *dest, const void *src, int c, size_t count);
从src复制0个或多个字节的字符到dest. 当字符c被复制或者count个字符被复制时, 复制停止.
如果字符c被复制, 函数返回这个字符后面紧挨一个字符位置的指针. 否则返回NULL.

int memcmp(const void *buf1, const void *buf2, size_t count);
比较buf1和buf2前面count个字节大小.
返回值< 0, 表示buf1小于buf2;
返回值为0, 表示buf1等于buf2;
返回值> 0, 表示buf1大于buf2.

int memicmp(const void *buf1, const void *buf2, size_t count);
比较buf1和buf2前面count个字节. 与memcmp不同的是, 它不区分大小写.
返回值同上.

char *strrev(char *string);
将字符串string中的字符顺序颠倒过来. NULL结束符位置不变. 返回调整后的字符串的指针.

char *_strupr(char *string);
将string中所有小写字母替换成相应的大写字母, 其它字符保持不变. 返回调整后的字符串的指针.

char *_strlwr(char *string);
将string中所有大写字母替换成相应的小写字母, 其它字符保持不变. 返回调整后的字符串的指针.

char *strchr(const char *string, int c);
查找字 串string中首次出现的位置, NULL结束符也包含在查找中. 返回一个指针, 指向字符c在字符串string中首次出现的位置, 如果没有找到, 则返回NULL.

char *strrchr(const char *string, int c);
查找字符c在字符串string中最后一次出现的位置, 也就是对string进行反序搜索, 包含NULL结束符.
返回一个指针, 指向字符c在字符串string中最后一次出现的位置, 如果没有找到, 则返回NULL.

char *strstr(const char *string, const char *strSearch);
在字符串string中查找strSearch子串. 返回子串strSearch在string中首次出现位置的指针. 如果没有找到子串strSearch, 则返回NULL. 如果子串strSearch为空串, 函数返回string值.

char *strdup(const char *strSource);
函数运行中会自己调用malloc函数为复制strSource字符串分配存储空间, 然后再将strSource复制到分配到的空间中. 注意要及时释放这个分配的空间.
返回一个指针, 指向为复制字符串分配的空间; 如果分配空间失败, 则返回NULL值.

char *strcat(char *strDestination, const char *strSource);
将源串strSource添加到目标串strDestination后面, 并在得到的新串后面加上NULL结束符. 源串strSource的字符会覆盖目标串strDestination后面的结束符NULL. 在字符串的复制或添加过程中没有溢出检查, 所以要保证目标串空间足够大. 不能处理源串与目标串重叠的情况. 函数返回strDestination值.

char *strncat(char *strDestination, const char *strSource, size_t count);
将源串strSource开始的count个字符添加到目标串strDest后. 源串strSource的字符会覆盖目标串strDestination后面的结束符NULL. 如果count大于源串长度, 则会用源串的长度值替换count值. 得到的新串后面会自动加上NULL结束符. 与strcat函数一样, 本函数不能处理源串与目标串重叠的情况. 函数返回strDestination值.

char *strcpy(char *strDestination, const char *strSource);
复制源串strSource到目标串strDestination所指定的位置, 包含NULL结束符. 不能处理源串与目标串重叠的情况.函数返回strDestination值.

char *strncpy(char *strDestination, const char *strSource, size_t count);
将源串strSource开始的count个字符复制到目标串strDestination所指定的位置. 如果count值小于或等于strSource串的长度, 不会自动添加NULL结束符目标串中, 而count大于strSource串的长度时, 则将strSource用NULL结束符填充补齐count个字符, 复制到目标串中. 不能处理源串与目标串重叠的情况.函数返回strDestination值.

char *strset(char *string, int c);
将string串的所有字符设置为字符c, 遇到NULL结束符停止. 函数返回内容调整后的string指针.

char *strnset(char *string, int c, size_t count);
将string串开始count个字符设置为字符c, 如果count值大于string串的长度, 将用string的长度替换count值. 函数返回内容调整后的string指针.

size_t strspn(const char *string, const char *strCharSet);
查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外) 在string串中首次出现的位置序号. 返回一个整数值, 指定在string中全部由characters中的字符组成的子串的长度. 如果string以一个不包含在strCharSet中的字符开头, 函数将返回0值.

size_t strcspn(const char *string, const char *strCharSet);
查找strCharSet串中任何一个字符在string串中首次出现的位置序号, 包含字符串结束符NULL.
返回一个整数值, 指定在string中全部由非characters中的字符组成的子串的长度. 如果string以一个包含在strCharSet中的字符开头, 函数将返回0值.

char *strspnp(const char *string, const char *strCharSet);
查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外) 在string串中首次出现的位置指针. 返回一个指针, 指向非strCharSet中的字符在string中首次出现的位置.

char *strpbrk(const char *string, const char *strCharSet);
查找strCharSet串中任何一个字符在string串中首次出现的位置, 不包含字符串结束符NULL.
返回一个指针, 指向strCharSet中任一字符在string中首次出现的位置. 如果两个字符串参数不含相同字符, 则返回NULL值.

int strcmp(const char *string1, const char *string2);
比较字符串string1和string2大小.
返回值< 0, 表示string1小于string2;
返回值为0, 表示string1等于string2;
返回值> 0, 表示string1大于string2.

int stricmp(const char *string1, const char *string2);
比较字符串string1和string2大小,和strcmp不同, 比较的是它们的小写字母版本.返回值与strcmp相同.

int strcmpi(const char *string1, const char *string2);
等价于stricmp函数, 只是提供一个向后兼容的版本.

int strncmp(const char *string1, const char *string2, size_t count);
比较字符串string1和string2大小,只比较前面count个字符. 比较过程中, 任何一个字符串的长度小于count, 则count将被较短的字符串的长度取代. 此时如果两串前面的字符都相等, 则较短的串要小.
返回值< 0, 表示string1的子串小于string2的子串;
返回值为0, 表示string1的子串等于string2的子串;
返回值> 0, 表示string1的子串大于string2的子串.

int strnicmp(const char *string1, const char *string2, size_t count);
比较字符串string1和string2大小,只比较前面count个字符. 与strncmp不同的是, 比较的是它们的小写字母版本. 返回值与strncmp相同.

char *strtok(char *strToken, const char *strDelimit);
在strToken 串中查找下一个标记, strDelimit字符集则指定了在当前查找调用中可能遇到的分界符. 返回一个指针, 指向在strToken中找到的下一个标记. 如果找不到标记, 就返回NULL值. 每次调用都会修改strToken内容, 用NULL字符替换遇到的每个分界符.

二、子串的处理
1.子串的获取
1.substr(int pos = 0,int n = npos) const,返回pos开始的n个字符组成的字符串,如str.substr(0,5),获取从第0个字符开始的5个字符
string str = “#abcd”;
string r = str.substr(0,1); //r="#";
2. erase(intpos = 0,int n = npos) const,擦除从pos开始的npos个字符。
string str = “12345”;
str.erase(0,3); //擦除从1开始的3个字符,str = “45”
str.erase(1,1); //str = “1345”
str.erase(1); //擦除从第1个字符开始的所有字符,str = “1”

2.子串的查找

1.find,查找子串
int find(char c, int pos = 0) const;//从pos开始查找字符c在当前字符串的位置
int find(const char *s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置
int find(const char *s, int pos, int n) const;//从pos开始查找字符串s中前n个字符在当前串中的位置
int find(const string &s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置

string str = “a b c d”;
int pos = str.find(’ '); //返回空格的位置,pos = 1;

  1. find_first_of,查找字符c第一次在字符串中出现的位置,如果不存在则返回-1
    string str = “a b c d”;
    int pos = str.find_first_of(’ '); //pos = 1;

  2. find_first_not_of,查找字符串中第一个不是字符c的字符位置,一般可以配合erase来使用,用来处理字符串前缀
    string str = “…abcd”;
    int pos = str.find_first_not_of(’.’); //pos = 4
    str.erase(0,str.find_first_not_of(’.’)); //去掉前缀‘.’,str = “abcd”

  3. find_last_of

  4. find_last_not_of

按空格拆分字符串,存入数组
stl
#include
#include
#include

string str = “hello world!”;
string strarry[10];
stringstream ss(str);
int cnum = 0;
while (ss >> strarry[cnum]) {
cnum++;
}

正则表达式(sregex_token_iterator)
regex split("\s");
sregex_token_iterator
p(str.begin(),str.end(),split,-1);
sregex_token_iterator end;
vector words;
while(p!=end){
words.push_back(*p++);
}

去掉字符串首尾空格
stl(erase,find)
s.erase(0,s.find_first_not_of(’ ‘));//erase(pos,len)
s.erase(s.find_last_not_of(’ ')+1,s.size());

正则表达式
regex htblank("^\s+|\s+$");
str = regex_replace(str,htblank,"");

字符串中连续空格变为单个空格
1.stl(find,replace)
//stl
int pos = s.find(" “);
while(pos!=-1){
s.replace(pos,2,” “);
pos = s.find(” ");
}

2.正则表达式
regex midblank("\s{2,}");
str = regex_replace(str,midblank," ");

提取字符串中的字母、数字
regex notword("\W");
sregex_token_iterator
p(s.begin(),s.end(),notword,-1);
sregex_token_iterator end;
string result;
while(p!=end){
result += p++;
}
//一定要用新的字符串保存
p
/原因:程序员负责确保传递给迭代器构造函数的 std::basic_regex 对象活得长于迭代器。因为迭代器存储指向 regex 的指针,故在销毁 regex 后自增迭代器会访问悬垂指针。/
/作者把s.clear()重用,结果就是第一个字符会变成空格,蜜汁调了很久/

字符的处理
1.大小写转换
使用#include 里的transform(str.begin(),str.end(),str.begin(),::tolower),参考c++中常用的大小写转换
#include
#include

string str1,str2;
str1 = “ABcdEFG”;
str2 = “ABcdEFG”;
//change str1 to “abcdefg”
transform(str1.begin(),str1.end(),str1.begin(),::tolower);
//change str2 to “ABCDEFG”
transform(str2.begin(),str2.end(),str2.begin(),::toupper);

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

新城里的旧少年^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值