C++中的string类用法简介_c++ string-程序员宅基地

技术标签: C++  数据结构与算法  String  C/C++编程语言  

本文主要介绍C++中的string类的常见用法。

1. 概述

string是C++标准库的一个重要的部分,主要用于字符串处理。可以使用输入输出流方式直接进行string操作,也可以通过文件等手段进行string操作。同时,C++的算法库对string类也有着很好的支持,并且string类还和c语言的字符串之间有着良好的接口。

2. 常见用法

2.1 string转换为char*

方法一:使用 c_str() 方法,代码(stringsimple.cpp)如下:

#include <string>
#include <iostream>
#include <stdio.h>

using namespace std;

int main()
{
    string strOutput = "Hello World";

    cout << "[cout] strOutput is: " << strOutput << endl;

    // string 转换为 char*
    const char* pszOutput = strOutput.c_str();
    
    printf("[printf] strOutput is: %s\n", pszOutput);

    return 0;
}

编译并执行上述代码,结果如下:

上述代码执行结果说明:

  • cout 可直接输出 string 类的对象的内容;
  • 使用 c_str() 方法转换 string 类型到 char* 类型时,需要为char*添加 const 关键字;
  • printf() 函数不能直接打印 string 类的对象的内容,可以通过将 string 转换为 char* 类型,再使用 printf() 函数打印。

2.1.1 data()方法与c_str()方法

data()方法与c_str()方法相似,都返回 const char* 类型。两者区别和联系如下:

  • 在C++98版本中,c_str()返回 const char* 类型,返回的字符串会以空字符(null character)结尾;
  • 在C++98版本中,data()返回 const char* 类型,返回的字符串不以空字符(null character)结尾;
  • 在C++11版本中,c_str()与data()用法相同(Both string::data and string::c_str are synonyms and return the same value.)

2.2 计算string长度、string字符串比较

示例代码如下:

#include <string>
#include <iostream>

#define HELLOSTR "Hello World"

using namespace std;

int main()
{
    string strOutput = "Hello World";

    int nLen = strOutput.length();

    cout << "the length of strOutput is: " << nLen << endl;

    if (0 == strOutput.compare(HELLOSTR))
    {
        cout << "strOutput equal with macro HELLOSTR" << endl;
    }

    return 0;
}

编译并执行上述代码,结果如下:

[root@node1 /opt/liitdar/mydemos/simples]# ./stringsimple2 
the length of strOutput is: 11
strOutput equal with macro HELLOSTR
[root@node1 /opt/liitdar/mydemos/simples]# 

上述代码执行结果说明:

  • string类型可直接使用 length() 方法计算字符串长度,该方法计算结果为字符串的实际长度,如本例中"Hello World"字符串的长度为11;
  • string类型可使用 compare(const string& str) 方法进行字符串比较。

2.3 string对象判空

可使用 empty() 方法对string类型的对象进行判空,如下:

    if (str2.empty())
    {
        cout << "str2 is empty." << endl;
    }

2.4 char*、char[]转换为string

将 char*、char[] 转换为 string 类型时,直接进行赋值操作,将 char*、char[] 的变量赋值给 string 对象即可。

说明:这里所说的“赋值”操作,实际上是将 char*、char[] 定义的字符串的首地址赋值给 string 对象了。

示例代码(stringtochar.cpp)如下:

#include <string>
#include <iostream>

using namespace std;

int main()
{
    const char* pszName = "liitdar";
    char pszCamp[] = "alliance";

    string strName;
    string strCamp;

    strName = pszName;
    strCamp = pszCamp;

    cout << "strName is: " << strName << endl;
    cout << "strCamp is: " << strCamp << endl;

    return 0;
}

编译并执行上述代码,结果如下:

2.5 string类的find方法

使用string类的find方法,在字符串中检索自字符串是否存在。

2.5.1 用法

用法如下:

size_t find (const string& str, size_t pos = 0) const;
size_t find (const char* s, size_t pos = 0) const;
size_t find (const char* s, size_t pos, size_t n) const;
size_t find (char c, size_t pos = 0) const;

2.5.2 返回值

find函数返回值:

The position of the first character of the first match. If no matches were found, the function returns string::npos.

size_t is an unsigned integral type (the same as member type string::size_type).

2.5.3 示例代码

find方法的示例代码(string_find_test1.cpp)如下:

#include <string>
#include <iostream>

using namespace std;

int main()
{
    // 待检索的字符串
    string strOutput = "|0|1|2|";
    // 需要检索的子串
    string strObj = "|1|";

    // 子串位于字符串中的位置
    size_t nLoc = strOutput.find(strObj);
    // 如果检索到子串在字符串中,则打印子串的位置
    if (nLoc != string::npos)
    {
        cout << "nLoc is: " << nLoc << endl;
    }

    return 0;
}

编译并执行上述代码,结果如下:

2.6 string类的insert方法

使用string类的insert方法,向字符串中插入字符(串)。官方的定义如下:

Inserts additional characters into the string right before the character indicated by pos (or p).

2.6.1 用法

string (1) string& insert (size_t pos, const string& str);
substring (2) string& insert (size_t pos, const string& str, size_t subpos, size_t sublen);
c-string (3) string& insert (size_t pos, const char* s);
buffer (4) string& insert (size_t pos, const char* s, size_t n);
fill (5)

string& insert (size_t pos, size_t n, char c);

void insert (iterator p, size_t n, char c);

single character (6) iterator insert (iterator p, char c);
range (7)

template <class InputIterator>

    void insert (iterator p, InputIterator first, InputIterator last);

2.6.2 示例代码

insert方法的示例代码(string_insert_test1.cpp)如下:

#include <iostream>
#include <string>

using namespace std;

int main()
{
    string strDemo = "I am";

    strDemo.insert(4, " good.");

    cout << "strDemo is: " << strDemo << endl;

    return 0;
}

编译并执行上述代码,结果如下:

2.7 int类型转为string类的方法

这里介绍两种常见的 int 类型转换为 string 类的方法,示例代码如下:

#include <string>
#include <iostream>
#include <sstream>

using namespace std;

int main()
{
    // 方法1
    int nNum1 = 123;
    stringstream ss;

    ss << nNum1;
    string strTest1 = ss.str();
    cout << "strTest1 is: " << strTest1 << endl;

    /*
    string strTest2;
    strTest2 << ss;     // stringstream 未定义 << 操作符,故此句报错
    cout << "strTest2 is: " << strTest2 << endl;
    */

    string strTest3;
    ss >> strTest3;
    cout << "strTest3 is: " << strTest3 << endl;

    // 方法2
    int nNum2 = 456;
    string strTest4;
    strTest4 = to_string(nNum2);    // C++11 标准
    cout << "strTest4 is: " << strTest4 << endl;

    return 0;
}

编译并执行上述代码,结果如下:

2.7 替换字符串中的空格

替换字符串中的空格,是一种常见的应用场景,下面通过代码示例介绍使用 string 类实现字符串中空格替换的方法。

示例代码如下:

// 面试题:替换空格
// 题目:请实现一个函数,把字符串中的每个空格替换成"%20"。例如输入“We are happy.”,
// 则输出“We%20are%20happy.”。

#include <iostream>
#include <string>

/* length 为字符串str可供使用的最大容量,大于或等于字符串str的实际长度 */
void ReplaceBlank(string & str, const int & length)
{
    if (str == "" && length <= 0)
    {
        return;
    }

    // originalLength为字符串str的实际长度
    int originalLength = 0;
    int numberOfBlank = 0;
    for (int i = 0; str[i] != '\0'; i++)
    {
        ++ originalLength;

        if (str[i] == ' ')
        {
            ++ numberOfBlank;
        }
    }

    // newLength为把空格替换成'%20'之后的长度
    int newLength = originalLength + numberOfBlank * 2;
    if (newLength > length)
    {
        return;
    }

    // 根据空格数量,重新分配str所占空间
    str.resize(newLength);
    
    // 设定原始字符串和更新后字符串的索引值
    int indexOfOriginal = originalLength - 1;
    int indexOfNew = newLength - 1;
    // 由尾至头,依次检索原始字符串内容
    while (indexOfOriginal >= 0 && indexOfNew > indexOfOriginal)
    {
        if (str[indexOfOriginal] == ' ' && numberOfBlank != 0 )
        {
            // 具体的替换位置与原始字符串中空格的数量有关
            // 需根据原始字符串中空格的数量设置偏移量
            str.replace(indexOfOriginal + (numberOfBlank - 1) * 2, 3, "%20");
            
            -- numberOfBlank;
            indexOfNew = indexOfNew - 3;
        }
        else
        {
            str.replace(indexOfNew, 1, 1, str[indexOfOriginal]);
            -- indexOfNew;
        }

        -- indexOfOriginal;
    }
}

// ==================== 测试代码 ====================
void Test(const string & testName, string & str, const int & length, const string & expected)
{
    if (testName != "")
    {
        cout << testName << " begins: " << endl;
    }
    
    if (expected == "" && str == "")
    {
        cout << "passed." << endl;
        return;
    }

    ReplaceBlank(str, length);

    if (expected == "" && str != "")
    {
        cout << "failed." << endl;
    }
    else if (0 == str.compare(expected))
    {
        cout << "passed." << endl;
    }
    else
    {
        cout << "failed." << endl;
    }
}

// 空格在句子中间
void Test1()
{
    const int & length = 100;
    string str = "hello world";
    
    Test("Test1", str, length, "hello%20world");
}

// 空格在句子开头
void Test2()
{
    const int & length = 100;
    string str = " helloworld";
    
    Test("Test2", str, length, "%20helloworld");
}

// 空格在句子末尾
void Test3()
{
    const int & length = 100;
    string str = "helloworld ";
    
    Test("Test3", str, length, "helloworld%20");
}

// 连续有两个空格
void Test4()
{
    const int & length = 100;
    string str = "hello  world";
    
    Test("Test4", str, length, "hello%20%20world");
}

// 传入空字符串
void Test5()
{
    string str = "";
    
    Test("Test5", str, 0, "");
}

//传入内容为一个空格的字符串
void Test6()
{
    const int & length = 100;
    string str = " ";
    
    Test("Test6", str, length, "%20");
}

// 传入的字符串没有空格
void Test7()
{
    const int & length = 100;
    string str = "helloworld";
    
    Test("Test7", str, length, "helloworld");
}

// 传入的字符串全是空格
void Test8()
{
    const int & length = 100;
    string str = "   ";
    
    Test("Test8", str, length, "%20%20%20");
}

int main()
{
    Test1();
    Test2();
    Test3();
    Test4();
    Test5();
    Test6();
    Test7();
    Test8();

    return 0;
}

上述代码的运行结果如下:

2.8 获取string最后一个字符

使用back函数获取字符串最后一个字符,用法如下:

char c = s.back();

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/liitdar/article/details/80498634

智能推荐

linux描述分区文件fa,鸟哥私房菜 第三章 主机规划与磁盘分区 学习笔记-程序员宅基地

文章浏览阅读68次。在鸟哥的书里面,这句话是经常强调的:在linux系统中,每个设备都被当做是一个文件来对待。目前,我还不能很深入的体会这句话。在这里先记下来,日后慢慢理解。1.下面列出几个常见的设备与其linux当中的文件名,如下:IDE硬盘 /dev/hd[a-d]SCSI/SATA/USB硬盘..._linux描述分区的文件名

Django的ORM操作-程序员宅基地

文章浏览阅读451次。命令,读取已经注册么给app中的migrations目录将配置文件 -> 转换成:生成表,修改表 SQL -> 连接数据库去运行。在app中的models.py中按照规则编写类 ===> 表结构。:请不要再手动去修改数据的表结构 + 时刻保证 ORM和数据表是对应。特点:开发效率高、执行效率低( 程序写的垃圾SQL )。安装MySQL & 启动MySQL服务。orm,关系对象映射,本质翻译的。settings.py,连接数据库。settings.py,注册app。实现:创建表、修改表、删除表。

SVD图像处理(MATLAB)-程序员宅基地

文章浏览阅读440次。使用SVD处理图像模拟演示。

matlab仿真受介质影响的磁场,MATLAB仿真带电粒子在磁场中磁镜现象-程序员宅基地

文章浏览阅读153次。MATLAB仿真带电粒子在磁场中磁镜现象【摘要】借助MATLAB数学工具软件,使用数值计算的方法计算带电粒子磁场中的运动方程,对非均匀磁场的磁镜现象进行仿真,使人们对带电粒子在磁场磁镜现象有个更直观的了解。【关键词】MATLAB;带电粒子;磁场;磁镜现象1.引言对于带电粒子在磁场中的磁镜现象,人们都有了一定的认识,但是却不能对其有比较直观形象的想象。为了比较直观形象的认识带电粒子在磁场中的磁镜现象..._带电粒子在均匀磁场中受洛伦兹力作用matlab

Markdown (CSDN) MD编辑器(二)- 文本样式(更改字体、字体大小、字体颜色、加粗、斜体、高亮、删除线)_markdown语法加粗-程序员宅基地

文章浏览阅读1.4w次,点赞31次,收藏93次。介绍使用 markdown 编辑器时,利用html的 font、mark、strong、em、del、big、small等标签改变文本的颜色、字体、字体大小、加粗字体、斜体、高亮等_markdown语法加粗

初级胆汁酸和次级胆汁酸_初级胆汁酸和次级胆汁酸有哪些-程序员宅基地

文章浏览阅读9.1k次,点赞2次,收藏6次。人体内的微生物通过作用到代谢物上面影响宿主的稳态. 所以在微生物研究中, 代谢研究非常的重要. 在target metabolomics里通常会测SCFA和Bile acids.因为对bile acid的各种初级以及次级有诸多疑惑, 所以这里查阅资料的总结.最开始还是从wiki入手, 然后再有初步了解之后再去看paper里面说的.0. 什么是bile salts大量的胆汁酸在肝脏合成, 胆汁酸和牛磺酸, 甘氨酸通常共轭结合, 他们叫做bile salts.1.什么是primar..._初级胆汁酸和次级胆汁酸有哪些

随便推点

智能优化算法:麻雀搜索算法-附代码-程序员宅基地

文章浏览阅读10w+次,点赞209次,收藏1.6k次。2020智能优化算法:麻雀搜索算法-附代码文章目录2020智能优化算法:麻雀搜索算法-附代码1.算法原理2.算法结果3.参考文献4.Matlab代码摘要:麻雀搜索算法(Sparrow Search Algorithm, SSA)是于2020年提出的。SSA 主要是受麻雀的觅食行为和反捕食行为的启发而提出的。该算法比较新颖,具有寻优能力强,收敛速度快的优点1.算法原理建立麻雀搜索算法的数学模型,主要规则如下所述:发现者通常拥有较高的能源储备并且在整个种群中负责搜索到具有丰富食物的区域,为所有的加_麻雀搜索算法

成功解决IDEA创建SpringBoot项目时没有web文件夹_idea创建web项目没有web文件夹-程序员宅基地

文章浏览阅读5.1k次,点赞6次,收藏9次。【版权所有,文章允许转载,但须以链接方式注明源地址,否则追究法律责任】原因1.在这块他不是没有文件夹,idea后边把web改成Spring Web了,你就点击那个对勾就可以了2.创建完项目之后发现没有WEB-INFO文件夹点击左上角File–>Projects Structure–>Facets–>Web–>+最后web文件夹就出来了..._idea创建web项目没有web文件夹

达梦数据库实时主备环境的搭建(DM7)-程序员宅基地

文章浏览阅读1.6k次,点赞2次,收藏10次。1 环境说明各主备库的实例名建议采用“组名_守护环境_序号”的方式命名,方便按组区分不同实例,注意总长度不能超过16。本示例中组名为“GRP1”,配置为实时主备,主库命名为“GRP1_DM_01”,备库命名为“GRP1_DM_02”。配置环境说明:主机类型IP地址实例名操作系统主库10.10.35.114(外部服务)1.1.1.10(内部通信)GRP1_DM_0...

java源码分析(五)---HashMap源码_if (var2 >= 1073741824) { this.threshold = integer-程序员宅基地

文章浏览阅读726次。吐槽今天天气好冷啊,真的是冻死了,自己下午出去吃了一顿羊肉泡,美滋滋。回来啃下HashMap的源码。前置条件在看HashMap源码之前我们有两个前置条件:Hash的概念,Hash函数的概念,Hash表的概念Map接口的源码分析当我们看完前置条件,然后再去看下HashMap的源码,解决以下问题。什么时候使用HashMap?简单的介绍下HashMapHashMap的工作原理Ha..._if (var2 >= 1073741824) { this.threshold = integer.max_value; return var1; }

小程序 video 控制器外观调整_可编程逻辑控制器(PLC)软件语言概述-程序员宅基地

文章浏览阅读106次。使用可编程逻辑控制器(PLC)的一个重要部分 ,IEC 61131-3是可编程逻辑控制器国际标准的第三部分。在本标准的这一部分中,列出了PLC的软件体系架构和有效的编程语言。该标准列出了五种不同的语言,其中三种是图形语言,另外两种是基于文本的。语言如下:阶梯图;功能区块图;顺序功能流程图;结构化文字;指令表(第3版标准已弃用)。阶梯图梯形图,通常称为梯形逻辑,是用于PLC编程的最主要语言之一。功能..._在vido中什么是plc组件

ArcGIS 桌面系统_arcgis桌面的几个组成-程序员宅基地

文章浏览阅读816次。ArcGIS桌面系统主要由 ArcMap,ArcCatalog,ArcToolbox三部分组成。利用这三个应用模块,我们可以完成各种GIS任务:从简单的地图显示,制作,到复杂的数据管理,地理分析ArcGIS桌面是集成的,可伸缩性的系统,可以满足不同用户的需要。ArcMapArcMap把传统的空间数据编辑、查询、显示、分析、报表和制图等GIS功能集成到一个简单的可扩展_arcgis桌面的几个组成

推荐文章

热门文章

相关标签