C++学习-string类

个人对string的不详尽笔记

笔记整理自复制粘贴自:
C语言中文网C++ string类(C++字符串)完全攻略
CSDN:字符串比较原理(strcmp,string)


  • 头文件<string>

  • 初始化

string s1(); //s1=""
string s2("Hellow");//s2="Hellow"
string s3(4,'K');//s3="KKKK"
string s4("12345",1,3);	//s4="234"(从下表1开始长度为3的字符串)
//或
string s1=(); //s1=""
string s2="Hellow";//s2="Hellow"
string s2=("Hellow");//s2="Hellow"
//以下error
string s3(4,'K');
string s4("12345",1,3);
//以上保持用不含等号的就行

string不能接受一个整型参数或字符型参数,所以以下全 部 木 大

string s1('K');
string s2(123);
//同样不能
string s1='K';
string s2=123;
  • 对string对象赋值
    可以用charchar*型变量,常量对string进行赋值
string s1;
s1="K";	//s1=“K”
s2="Hellow" 	//s2="Hellow"
s3='k';		s3="k"
//不要用括号

以及assign成员函数(和初始化差不多)

sring s1("12345"),s2;
s2.assign(s1);		//s2=s1;
s2.assign(s1,1,2);		//s2="23"
s2.assign("abcde",2,3);		//s2="cde"
s2.assign(3,'K');		//s2="KKKKK"
  • 求长度
    和字符数组差不多
    直接用string里的.length()和.size()
    如:
    cout<<str.length()<<' '<<str.size();
    
    不能是length(str)和str.size()。
  • 字符串的连接
    可以通过‘+’或‘+=’进行字符串的连接:
string str1("Hellow") str2("world") str3("!") str4;
char arr1[20]="emmm" arr2[20]="mmmmm"
//string可以与字符常量或字符串(如“aaaaa”)或字符数组相加
str4=str1+str2+ste3;
str1+=str2+'a';
str4=str2+"aaaaa";
str1+=arr1;
//以下error
str4=arr1+arr2;
str4=arr1+arr2+str1;
str4+=arr1+'b';

也就是只要记住字符常量和字符串(如“aaaaa”)和字符数组不能直接相加,其他直接按理解去想就好了
 也可以用string类的成员函数append

string s1("123"), s2("abc");
s1.append(s2);  // s1 = "123abc"
s1.append(s2, 1, 2);  // s1 = "123abcbc"
s1.append(3, 'K');  // s1 = "123abcbcKKK"
s1.append("ABCDE", 2, 3);  // s1 = "123abcbcKKKCDE"
  • string对象的比较
    对象的比较字符串比较分为两种情况,一种是单个字符比较大小,一种是多个字符构成的字符串整体比较大小。

字符与字符串比较原理
字符串与字符比较原理其实都是比较单个字符的ASCII码值。

如果单纯比较长度,直接调用类似于strlen()之类的函数就可以,加以比较即可.
如果比较字符串的大小,则比较的是字符的ASCII编码的大小.你搜索一下ASCII码表就可以得知每一个ASCII字符的大小.

在比较字符串时,设置一个计数器,从零开始,一直循环到最短的那个字符结束,一位一位进行比较,

1.如果 字符串1的第n位的ASCII码值 等于 字符串2的第n位的ASCII码值 则 继续比较下一位

2.如果 字符串1的第n位的ASCII码值 大于 字符串2的第n位的ASCII码值 则 输出结果:1,表示字符串1 > 字符串2;

3.如果 字符串1的第n位的ASCII码值 小于 字符串2的第n位的ASCII码值 则 输出结果:-1 表示字符串1 < 字符串2;

4.如果 每一位的ASCII码值都相等,而且长度相同, 则 输出结果:0 表示字符串1 == 字符串2;

5.如果 字符串1是字符串2的前m位,例如 abcd 与abcdef 比较, 则 字符串1<字符串2. 原因是,到第5位时,字符串1的ASCII值是0,而字符串2的ASCII值为'e',即十进制的101,当然是字符串2大了. 具体到 cds和lesoqd 从第一位开始,'c'和'l'比较,当然是'c' < 'l'了,所以,"cds" < "lesoqd"
那用什么比较?
在知道原理后, >、<、==、!= 等等不比多说,接下来介绍 string 类成员函数 compare,用法举例如下:

string s1("hello"), s2("hello, world");
int n = s1.compare(s2);
n = s1.compare(1, 2, s2, 0, 3);  //比较s1的子串 (1,2) 和s2的子串 (0,3)
n = s1.compare(0, 2, s2);  // 比较s1的子串 (0,2) 和 s2
n = s1.compare("Hello");
n = s1.compare(1, 2, "Hello");  //比较 s1 的子串(1,2)和"Hello”
n = s1.compare(1, 2, "Hello", 1, 2);  //比较 s1 的子串(1,2)和 "Hello" 的子串(1,2)
  • 求string对象的子串
    用string的成员函数substr,调用时,如果省略 m 或 m 超过了字符串的长度,则求出来的子串就是从下标 n 开始一直到字符串结束的部分。例如:
tring s1 = "this is ok";
string s2 = s1.substr(2, 4);  // s2 = "is i"
s2 = s1.substr(2);  // s2 = "is is ok"
  • 交换两 string 对象内容
    swap 成员函数可以交换两个 string 对象的内容。例如:
string s1("West”), s2("East");
s1.swap(s2);  // s1 = "East",s2 = "West"
  • 查找子串和字符
    string 类有一些查找子串和字符的成员函数,它们的返回值都是子串或字符在 string 对象字符串中的位置(即下标)。如果查不到,则返回 string::npos。string: :npos 是在 string 类中定义的一个静态常量。这些函数如下:
    • find:从前往后查找子串或字符出现的位置。
    • rfind:从后往前查找子串或字符出现的位置。
    • find_first_of:从前往后查找何处出现另一个字符串中包含的字符。例如:
    • s1.find_first_of("abc"); //查找s1中第一次出现"abc"中任一字符的位置
    • find_last_of:从后往前查找何处出现另一个字符串中包含的字符。
    • find_first_not_of:从前往后查找何处出现另一个字符串中没有包含的字符。
    • find_last_not_of:从后往前查找何处出现另一个字符串中没有包含的字符。

下面是 string 类的查找成员函数的示例程序。

#include <iostream>
#include <string>
using namespace std;
int main()
{
    string s1("Source Code");
    int n;
    if ((n = s1.find('u')) != string::npos) //查找 u 出现的位置
        cout << "1) " << n << "," << s1.substr(n) << endl;
    //输出 l)2,urce Code
    if ((n = s1.find("Source", 3)) == string::npos)
        //从下标3开始查找"Source",找不到
        cout << "2) " << "Not Found" << endl;  //输出 2) Not Found
    if ((n = s1.find("Co")) != string::npos)
        //查找子串"Co"。能找到,返回"Co"的位置
        cout << "3) " << n << ", " << s1.substr(n) << endl;
    //输出 3) 7, Code
    if ((n = s1.find_first_of("ceo")) != string::npos)
        //查找第一次出现或 'c'、'e'或'o'的位置
        cout << "4) " << n << ", " << s1.substr(n) << endl;
    //输出 4) l, ource Code
    if ((n = s1.find_last_of('e')) != string::npos)
        //查找最后一个 'e' 的位置
        cout << "5) " << n << ", " << s1.substr(n) << endl;  //输出 5) 10, e
    if ((n = s1.find_first_not_of("eou", 1)) != string::npos)
        //从下标1开始查找第一次出现非 'e'、'o' 或 'u' 字符的位置
        cout << "6) " << n << ", " << s1.substr(n) << endl;
    //输出 6) 3, rce Code
    return 0;
}
  • 替换子串
    replace 成员函数可以对 string 对象中的子串进行替换,返回值为对象自身的引用。例如:
 string s1("Real Steel");
s1.replace(1, 3, "123456", 2, 4);  //用 "123456" 的子串(2,4) 替换 s1 的子串(1,3)
cout << s1 << endl;  //输出 R3456 Steel
string s2("Harry Potter");
s2.replace(2, 3, 5, '0');  //用 5 个 '0' 替换子串(2,3)
cout << s2 << endl;  //输出 HaOOOOO Potter
int n = s2.find("OOOOO");  //查找子串 "00000" 的位置,n=2
s2.replace(n, 5, "XXX");  //将子串(n,5)替换为"XXX"
cout << s2 < < endl;  //输出 HaXXX Potter
  • 插入字符串
    insert 成员函数可以在 string 对象中插入另一个字符串,返回值为对象自身的引用。例如:
  string s1("Limitless"), s2("00");
s1.insert(2, "123");  //在下标 2 处插入字符串"123",s1 = "Li123mitless"
s1.insert(3, s2);  //在下标 2 处插入 s2 , s1 = "Li10023mitless"
s1.insert(3, 5, 'X');  //在下标 3 处插入 5 个 'X',s1 = "Li1XXXXX0023mitless"
  • 删除子串
    erase 成员函数可以删除 string 对象中的子串,返回值为对象自身的引用。例如:
string s1("Real Steel");
s1.erase(1, 3);  //删除子串(1, 3),此后 s1 = "R Steel"
s1.erase(5);  //删除下标5及其后面的所有字符,此后 s1 = "R Ste"
  • 将 string 对象作为流处理
  • 用 STL 算法操作 string 对象
    以上两条本人没学不说了。
posted @ 2020-11-06 22:34  七铭的魔法师  阅读(95)  评论(0编辑  收藏  举报