优秀的编程知识分享平台

网站首页 > 技术文章 正文

【C++编程语言】string容器 概念 构造 赋值 拼接 查找 比较 插入 删除

nanyue 2025-01-26 23:39:10 技术文章 4 ℃

1.string基本概念

本质:

  • string是C++风格的字符串,而string本质是一个类

string和char*区别

  • char* 是一个指针
  • string是一个类,类内部封装了char* ,管理这个字符串,是一个char*型的容器

特点:

string类内部封装了很多成员方法

例如:查找find 拷贝copy 删除delete 替换replace 插入insert

string管理char*所分配的内存,不用担心复制越界和取值越界,由类内部进行负责

2.string构造函数

构造函数原型:

/*
    构造函数原型
    string();    //创建一个空字符串 例如string str;
    string(const char* s) //使用字符串s初始化
    string(const string& str)//使用一个string对象初始化另一个string对象  copy初始化
    string(int n,char c)   //使用n个字符c初始化
*/

void test01() {
    string s1;//默认构造

    const char* str = "hello word";
    string s2(str);
    cout << s2 << endl;//输出:hello Word

    string s3(s2);//拷贝构造   s2的值赋给s3
    cout << s3 << endl;//输出:hello Word

    string s4(3, 'c');
    cout << s3 << endl;//输出:ccc
}
int main() {
    test01();
    system("pause");
    return 0;
}

3.string赋值操作

功能描述:

给string字符串进行赋值

#include
#include
using namespace std;
/*
    string赋值操作
    string& operator=(const char* s);    char*类型字符串 赋值给当前的字符串
    string& operator=(const string &s);  把字符串s赋给当前字符串
    string& operator=(char s);           字符赋值给当前的字符串
    string& assign(const char *s);       把字符S赋给当前字符串
    string& assign(const char *s,int n);    把字符串s的前n个字符给当前的字符串
    string& assign(const string &s);    把字符串s赋给当前字符串
    string assign(int n,char c);        用n个字符c赋给当前字符串
*/
void test01() {

    string str1;
    str1 = "hello word";//"hellw word"是char类型的字符串
    cout << str1 << endl;

    string str2;
    str2 = str1;
    cout << str2 << endl;

    string str3;
    str3 = 'a';
    cout << str3 << endl;

    string str4;
    str4.assign("hello C++");
    cout << str4 << endl;

    string str5;
    str5.assign("hello C++",5);
    cout << str5 << endl;

    string str6;
    str6.assign(str5);
    cout << str6 << endl;

    string str7;
    str7.assign(10,'w');
    cout << str7 << endl;
}
int main() {
    test01();
    system("pause");
    return 0;
}

4.string字符串拼接

功能描述:

实现在字符串末尾拼接字符串

#include
#include
using namespace std;
/*
    string拼接操作
    string& operator += (const char* str)   重载+=操作符   把str字符串连接到最后
    string& operator += (const char c)   重载+=操作符      把c字符连接到最后
    string& operator += (const string& str)   重载+=操作符  把str字符串连接到最后
    string& append(const char *s)   把字符串s连接到当前字符串结尾
    string& append(const char *s,int n) 把字符串s的前n个字符连接到当前字符串结尾
    string& append(const string &s)  把s字符串连接到最后
    string& append(const string &s,int pos,int n) 字符串s中从POS开始的n个字符连接到字符串结尾
*/

void test01() {
    string str1 = "我爱";
    str1 += "玩游戏 ";
    str1 += ':';
    cout << str1 << endl;//输出   我爱玩游戏 :

    string str2 = "LOL  DNF";
    str1 += str2;
    cout << str1 << endl;//输出   我爱玩游戏 :LOL

    string str3 = "I";
    str3.append(" Love");
    cout << str3 << endl;//输出   I  LOVE

    str3.append("game abcde",4);
    cout << str3 << endl;//输出   I  LOVE   game
    
    str3.append(str2,4,3);//参数2是从那个位置截取,参数3是截取几个
    cout << str3 << endl;//输出   I  LOVE   DN
}
int main() {
    test01();
    system("pause");
    return 0;
}

5.string查找和替换

功能描述:

  • 查找:查找指定字符串是否存在
  • 替换:在指定的位置替换字符串
/*
    查找
    int find(const string& str,int pos = 0)const  查找字符串str第一次出现位置,从POS开始查找
    int find(const char* s,int pos = 0)const  查找字符串s第一次出现位置,从POS开始查找
    int find(const char* s,int pos ,int n)const  从pos位置查找字符s的前n个字符第一次出现位置
    int find(const char c,int pos = 0)const  查找字符c第一次出现位置,从POS开始查找
    int rfind(const string& str,int pos = npos)const  查找字符串str最后一次出现位置,从POS开始查找
    int rfind(const char* s,int pos = npos)const  查找字符串s最后一次出现位置,从POS开始查找
    int rfind(const char* s,int pos ,int n)const  从pos查找s的前n个字符最后一次出现的位置
    int rfind(const char c,int pos = 0)const  查找字符c最后一次出现的位置
    替换
    string& replace(int pos,int n,const string& str) 替换从POS开始n个字符为字符串str
    string& replace(int pos,int n,const char* s) 替换从POS开始n个字符为字符串s
*/

//字符串查找和替换
void test01() {
    //查找
    string str1 = "abcdefg";
    int pos = str1.find("e");
    cout << pos << endl;//返回值为 4  如果找不到是返回-1

    //替换
    string str2 = "111";
    str1.replace(1, 3, str2);
    cout << str1 << endl;//输出为:a111efg
}
int main() {
    test01();
    system("pause");
    return 0;
}

6.string字符串比较

功能描述:

  • 字符串之间的比较

比较方式:

字符串比较是按照字符的ASCLL码进行对比。

等于 返回值为0 大于返回值为1 小于返回值为-1

/*  函数原型
    int compare(const string &s)const  与字符串s比较
    int compare(const char *s)const  与字符串s比较
*/

//字符串比较   实际用途一般用于比较字符串是否相等,判断字符串大小的意义并不大
void test01() {
    
    string str1 = "hello";
    string str2 = "xllo";
    if (str1.compare(str2) == 0) {
        cout<<"str1与str2相等" << endl;
    }
    
}
int main() {
    test01();
    system("pause");
    return 0;
}

7.string单个字符的访问和修改

/*
    string中单个字符存取方式有两种  同时也是可以修改的
    char& operator[](int n);  通过[]方式取字符
    char& at(int n)      通过at方法获取字符
*/

void test01() {

    string str = "hello";
    //1.通过[]访问单个字符
    for (int i = 0; i < str.size(); i++) {
        cout << str[i] << endl;
    }

    //2.通过at访问单个字符
    for (int i = 0; i < str.size(); i++) {
        cout << str.at(i) << endl;
    }
    
    //同时还可以修改单个字符
    str[1] = '2';
    cout << str << endl;

}
int main() {
    test01();
    system("pause");
    return 0;
}

8.string插入和删除

功能描述:

  • 对string字符串进行插入和删除字符操作
/*
    string& insert(int pos,const char* s)   插入字符串
    string& insert(int pos,const string& str) 插入字符串
    string& insert(int pos,int n,char c)  在指定位置插入n个字符c
    string& erase(int pos,int n = npos)  删除从pos开始的n个字符
*/

//字符串的插入和删除
void test01() {
    string str = "hello";
    string str1 = "hello2";
    //插入
    str.insert(1, "111");
    cout << str << endl;//输出:h111ello
    str.insert(1, str1);
    cout << str << endl;//输出:hhello2111ello

    //删除
    str.erase(1, 2);
    cout << str << endl;//输出:hllo2111ello
    
}
int main() {
    test01();
    system("pause");
    return 0;
}

9.string子串的获取

功能描述:

  • 从字符串中获取想要的子串
#include "string容器.h"
#include
#include
using namespace std;
/*
    string substr(int pos = 0 , int n = npos) const;  返回由pos开始的n个字符组成的字符串
*/

//字符串的获取
void test01() {
    string str = "abcdefghe";
    string subStr = str.substr(1, 3);
    cout << subStr << endl;//输出:bcd
}
int main() {
    test01();
    system("pause");
    return 0;
}



Tags:

最近发表
标签列表