0. 写在最前面

希望大家收藏:

本文持续更新地址:https://haoqchen.site/2018/09/09/string-and-char/

也欢迎收藏我的另一篇总结:编程常用数据结构与函数总结(vector、list、stack、deque、字符串)

C++字符串处理有最原始的char以及string两种方式,这里对两种方式常用的功能进行总结及对比。

如果觉得还不错就点个赞,点个关注呗,博主会长期更新自己的学习和收获。

  string char*、char[]
头文件 #include <string> 不需要

定义

与初始化

string s1("abc");

string s2(s1);

string s3(4, 's');//初始化为4个's'

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() std::strlen(p)//#include <cstring>(C++写法)或者<string.h>(C写法)
容器大小 str.capacity()

数组形式p[],可以使用sizeof(p)来获得数组大小

指针形式没有容器概念,除非是new的,对指针用sizeof将得到指针本身的大小,由系统位数决定

倒置

#include <algorithm> // std::reverse

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;
}

比较字符串大小

一共五种重载形式

int compare (const string& str);
int compare (size_t pos, size_t len, const string& str);
int compare (size_t pos, size_t len, const string& str, size_t subpos, size_t sublen);
int compare (const char* s) const;
int compare (size_t pos, size_t len, const char* s);
int compare (size_t pos, size_t len, const char* s, size_t n);

返回与右边一致,其中pos表示从str的第几个元素开始比较,一共比较len个字符,如果不够,则有多少比较多少。subpos、sublen是相对比较字符串而言的

string重载了==、<等符号,可以直接用符号比较

string没有提供不区分大小写的比较,感觉可以读取出数据后通过右侧的函数来进行比较。

int strcmp(char* s1, char* s2);//区分字母大小写比较
当s1 < s2时,返回值<0; //对于第一个不相等的字符,s1对应的小于s2对应的,或者全相等,但是s1的字符数量少于s2的字符数量
当s1 = s2时,返回值=0; 
当s1 > s2时,返回值>0。

int stricmp(char* s1, char* s2);//不区分字母大小写

int strncmp(char* s1, char* s2, int n);//只比较前n个字符,区分大小

int strnicmp(char* s1, char* s2, int n);//之比较前n,不区分大小写

数字转

字符串

1、stringstream(多次使用需要使用clear()清除)

int N = 10;

stringstream ss;//#include <sstream>

string str;

ss << N;

ss >> str;

2、string = std::to_string(N)方法

只需包含<string>头文件即可

1、使用sprintf:#include <stdio.h>

char c[100];
int k=255;
sprintf(c,"%d",k);//d是有符号10进制数,u是无符号10进制

double a=123.321;
sprintf(c,”%.3lf”,a);

sprintf(c,"%x",k);//转换成16进制,如果想要大写的话可以用X,8进制是o
//c包含"ff" c[0]='f' c[1]='f'

2、itoa貌似跟平台有关,不建议使用。

字符串转数字

1、N = stringToNum<int>(str);//需要#include <sstream>

2、在<string>中实现的

int stoi (const string& str, size_t* idx = 0, int base = 10);//idx返回第一个非数字的指针索引,base默认10进制

long stol、unsigned long stoul、long long stoll、unsigned long long stoull、float stof、double stod、long double stold

3、stringstream//#include <sstream>

string a = "123.32";

double res;

stringstream ss;

ss << a;

ss >> res;

char a[10] = {"255"};
int b;
sscanf(a,"%d",&b);

char a[10] = {"ff"};//十六进制

int b;
sscanf(a,"%x",&b);

char str[]=”123.321”; 
double a; 
sscanf(str,”%lf”,&a);

另外也可以用atoi(),atol(),atof()

拷贝与

合并

char p[10];

std::size_t length = str.copy(p,5,0);//从第0个开始复制5个,返回有效复制的数量,需要在p最后添加'\0'

合并直接用+号即可

或者用.append()

string& append (const string& str);
string& append (const string& str, size_t subpos, size_t sublen);
string& append (const char* s);
string& append (const char* s, size_t n);
string& append (size_t n, char c);

char* strcpy(char* dest, char* src);//把从src地址开始且含有 ‘\0’结束符的字符串复制到以dest开始的地址空间。返回指向dest的指针。

char* strncpy(char* dest, char* src, int size_tn);//复制n个,这个复制不保证NULL结尾,需要自己初始化。

char* strcat(char* dest, char* src);//把src所指字符串添加到dest结尾处(覆盖dest结尾处的 ‘\0’)并添加 ‘\0’。返回指向dest的指针。且内存不可重叠。

char* strncat(char* dest, char* src, int n);//部分合并

用sprintf也行,但是效率不高。

插入与

替换

string& insert (size_t pos, const string& str);
string& insert (size_t pos, const string& str, size_t subpos, size_t sublen);
string& insert (size_t pos, const char* s);
string& insert (size_t pos, const char* s, size_t n);
string& insert (size_t pos,   size_t n, char c);

string& replace (size_t pos,        size_t len,        const string& str);
string& replace (size_t pos,        size_t len,        const string& str,
                 size_t subpos, size_t sublen);    
string& replace (size_t pos,        size_t len,        const char* s);
string& replace (size_t pos,        size_t len,        const char* s, size_t n);
string& replace (size_t pos,        size_t len,        size_t n, char c);

不存在

字符串

切割

string substr (size_t pos = 0, size_t len = npos):

std::string str2 = str.substr (3,5);//返回str的第3个开始的5个元素。可以配合find函数来实现针对特殊元素的切割

char* strtok (char* str,constchar* delimiters );//以delimiters中的每个字符作为分割符,将str剪切,返回一个个字符串。传入NULL时代表继续切割后续的。下面的程序预计输出hello boy this is heima。第二个参数可以是" ,\t\n\\"等。(其实就是将被切割的换成'\0'?待分割字符串的完整性会被破坏,而且线程不安全。具体分析请看strtok的安全性探讨)

IO函数

std::getline (std::cin,str,s);//这个不需要固定大小,但是速度慢,生成文件大。默认终止符是换行

cin.get(arrayname,size,s)//读取size-1个字符,在末尾添加'\0'遇终止符停止,返回是否成功。读取玩指针指向终止符。s默认换行

cin.getline(arrayname,size,s)//同上,只是指针指向终止符之后

C++字符串处理总结(char、string)相关推荐

  1. 字符串相关的类String

    String类 一.String类概述 二.String类的使用 1. 不可变性的体现 2. 对象的创建的两种方式及存储结构 2. 两种不同的连接方式的对比 三.String类和其他类的转换 1. 和 ...

  2. c# byte char string转换

    c# byte char string转换 在在做一些互操作的时候往往需要一些类型的相互转换,比如用c#访问 win32api的时候往往需要向api中传入DWORD参数 即:uint参数这些数值所表示 ...

  3. char string 区别

    由于在C++项目中,经常遇到处理字符方面的问题,故借此机会整理一下,让自己对于char , string 等有进一步的了解. 基本概念 由单引号括起来的一个字符成为char型字面值.双引号括起来的零个 ...

  4. [转载]c#中 uint--byte[]--char[]--string相互转换汇总

    在在做一些互操作的时候往往需要一些类型的相互转换,比如用c#访问win32api的时候往往需要向api中传入DWORD参数即:uint参数这些数值所表示的数据在实际的应用中可能需要以字符的形式显示,但 ...

  5. C 风格字符串与C++中string类区别

    1. 概述 字符串是若干个有效字符(字母.数字.专用字符.转义字符等)的序列.C语言中没有字符串变量,字符串不是存放在一个变量中,而是存放在一个字符型数组中.因此,为了存放字符串,常常在程序中定义字符 ...

  6. c#中 uint--byte[]--char[]--string相互转换汇总

    uint-----byte[]-----char[]-----string 在在做一些互操作的时候往往需要一些类型的相互转换,比如用c#访问win32api的时候往往需要向api中传入DWORD参数 ...

  7. java array to string_数组到字符串转换(Array to string conversion)

    数组到字符串转换(Array to string conversion) 这段代码有什么问题? 我不明白. 这是错误代码: 注意:第12行的C:\ xampp \ htdocs \ stage \ r ...

  8. MFC中char*,string和CString之间的转换

    string是使用STL时必不可少的类型,所以是做工程时必须熟练掌握的: char*是从学习C语言开始就已经和我们形影不离的了,有许多API都是以char*作为参数输入的.所以熟练掌握三者之间的转换十 ...

  9. java字符串常量池长度_Java String类相关知识梳理(含字符串常量池(String Pool)知识)...

    目录 1. String类是什么 1.1 定义 1.2 类结构 1.3 所在的包 2. String类的底层数据结构 3. 关于 intern() 方法(重点) 3.1 作用 3.2 字符串常量池(S ...

  10. java 字符串 面试_JAVA中String介绍及常见面试题小结

    字符串广泛应用 在 Java 编程中,在 Java 中字符串属于对象,Java 提供了 String 类来创建和操作字符串. 深刻认识String 1)String为字符串常量:即String对象一旦 ...

最新文章

  1. 基于Apache Flink的爱奇艺实时计算平台建设实践
  2. R语言ggplot2可视化配置多个子图中的相同分组使用相同的填充色实战
  3. Spring中Bean的生命周期是怎样的
  4. R语言实战学习笔记-高级数据管理
  5. UML用例图总结(转)
  6. 应用事件探查器优化SQL Server系统[转]
  7. 《机器学习实战》笔记(03):决策树
  8. 倍受好评的美国主机JustHost使用全攻略教程
  9. css grid随页面大小_CSS中的间距知识总结,前端开发中各种间距的使用及优缺点
  10. 我的MYSQL学习心得(十三) 权限管理
  11. python打乱列表的方法_python打乱列表
  12. Spring Cloud Hystrix服务容错 (学习总结)
  13. NVIDIA英伟达控制面板打不开解决办法win10
  14. html代码在线高亮美化,代码语法高亮美化显示插件CodeMirror
  15. E php短信平台接口
  16. v4l2驱动框架简介
  17. 计算机二级河南2020年12月报名时间,2020年3月河南省洛阳市计算机二级报名时间|网上报名入口【12月16日9:00开通】...
  18. Electron 使用 regedit 控制注册表(实现win文件右键菜单)
  19. 心灵奇旅最触动我的一段
  20. EXCEL常用函数——计算统计函数

热门文章

  1. 离散数学 图论基础知识总结
  2. Java版简易房屋购买系统
  3. php seo,内容SEO设置
  4. IDC报告深度解读:2023年CRM发展趋势分析
  5. 老房装修风格有哪些 老房装修设计要点
  6. 【力扣时间】【1705】【中等】吃苹果的最大数目
  7. 1号店订单系统水平分库的实践之路以及关键步骤
  8. Powershell Empire的使用
  9. rabbitmq四万字大全
  10. 计算机考研英语考哪个卷子,计算机考研试卷