C++ string类使用总结

string类

string类是一个模板类,它的定义如下:

typedef basic_string<char> string;

使用string类要包含头文件<string>

string对象的初始化

  • 正确的初始化方法
string s1("Hello");  // 一个参数的构造函数
string s2(8, ‘x’);   // 两个参数,s2中有8个x
string month = “March”;
  • 不提供以字符整数为参数的构造函数
    错误的初始化方法:
string error1 = ‘c’;  // 错
string error2(‘u’);   // 错
string error3 = 22;   // 错
string error4(8);     // 错
  • 可以将字符型赋值给string对象
string s;
s = ‘n’;
  • 构造的string太长而无法表达 -> 会抛出length_error异常
  • string对象的长度用成员函数length()读取
string s("hello");
cout << s.length() << endl;
  • string支持流读取运算符
string stringObject;
cin >> stringObject;
  • string支持getline函数
string s;
getline(cin, s);

样例程序

#include <iostream>
#include <string>
using namespace std;
int main() {
    string s1("Hello");
    cout << s1 << endl;
    string s2(8, 'x');
    cout << s2 << endl;
    string month = "March";
    cout << month << endl;
    string s;
    s='n';
    cout << s << endl;
    return 0;
}

程序输出:

Hello
xxxxxxxx
March
n

string的赋值和连接

  • =赋值
string s1("cat"), s2;
s2 = s1;
  • assign成员函数复制
string s1("cat"), s3;
s3.assign(s1);
  • assign成员函数部分复制
string s1("catpig"), s3;
s3.assign(s1, 1, 3);  //从s1中下标为1的字符开始复制3个字符给s3 s3 = "atp"
  • 单个字符复制
s2[5] = s1[3] = ‘a’;
  • 逐个访问string对象中的字符
string s1("Hello");
for(int i = 0; i< s1.length(); i++) {
    cout << s1.at(i) << endl;
    cout << s1[i] << endl;
}   

成员函数at会做范围检查, 如果超出范围, 会抛出out_of_range异常, 而下标运算符[]不做范围检查

  • +运算符连接字符串
string s1("good "), s2("morning! ");
s1 += s2;
cout << s1;   // "good morning! "
  • 用成员函数append连接字符串
string s1("good "), s2("morning! ");
s1.append(s2);    
cout << s1;
s2.append(s1, 3, s1.size());   //s1.size(), s1字符数
cout << s2;
//下标为3开始, s1.size()个字符
//如果字符串内没有足够字符, 则复制到字符串最后一个字符

比较string

  • 用关系运算符比较string的大小
  • == , >, >=, <, <=, !=
  • 返回值都是bool类型,成立返回true,否则返回false
string s1("hello"), s2("hello"), s3("hell");
bool b = (s1 == s2);
cout << b << endl;
b = (s1 == s3);
cout << b << endl;
b = (s1 > s3);
cout << b << endl;

输出:

1
0
1
  • 用成员函数compare比较string的大小
string s1("hello"), s2("hello"), s3("hell");
int f1 = s1.compare(s2);
int f2 = s1.compare(s3);
int f3 = s3.compare(s1);
int f4 = s1.compare(1, 2, s3, 0, 3);   //s1 1-2; s3 0-3
int f5 = s1.compare(0, s1.size(), s3);  //s1 0-end
cout << f1 << endl << f2 << endl << f3 << endl;
cout << f4 << endl << f5 << endl;

输出:

0   // hello == hello
1   // hello > hell
-1  // hell < hello
-3  // el < hell
1   // hello > hell

子串

  • 成员函数substr()
string s1("hello world"), s2;
s2 = s1.substr(4,5);
cout << s2 << endl;   // o wor

交换string

  • 成员函数swap()
string s1("hello world"), s2("really");
s1.swap(s2);
cout << s1 << endl;    // really
cout << s2 << endl;    // hello world

string的特性

  • 成员函数capasity()返回无需增加内存即可存放的字符数
  • 成员函数maximun_size()返回string对象可存放的最大字符数
  • 成员函数length()size()相同,返回字符串的大小/长度
  • 成员函数empty()返回string对象是否为空
  • 成员函数resize()改变string对象的长度
string s1("hello world");
cout << s1.capacity() << endl;
cout << s1.max_size() << endl;
cout << s1.size() << endl;
cout << s1.length() << endl;
cout << s1.empty() << endl;
cout << s1 << "aaa" << endl;
s1.resize(s1.length()+10);
cout << s1.capacity() << endl;
cout << s1.max_size() << endl;
cout << s1.size() << endl;
cout << s1.length() << endl;
cout << s1 << "aaa" << endl;
s1.resize(0);
cout << s1.empty() << endl;

输出(不同编译器上可能会不一样):

22    // capacity
18446744073709551599   // maximum_size
11   / length
11   // size
0   // empty
hello worldaaa    // string itself and "aaa"
22
18446744073709551599
21
21
hello worldaaa
1

寻找string中的字符

  • 成员函数find()
string s1("hello world");
s1.find("lo");   // 3
//在s1中从前向后查找 “lo” 第一次出现的地方
//如果找到, 返回 “lo”开始的位置, 即 l 所在的位置下标
//如果找不到, 返回 string::npos (string中定义的静态常量)

string s1("hello worlld");
cout << s1.find("ll", 1) << endl;
cout << s1.find("ll", 2) << endl;
cout << s1.find("ll", 3) << endl;
//分别从下标1, 2, 3开始查找 “ll”
  • 成员函数rfind()
string s1("hello world");
s1.rfind("lo");   // 3
//在s1中从后向前查找 “lo” 第一次出现的地方
//如果找到, 返回 “lo”开始的位置, 即 l 所在的位置下标
//如果找不到, 返回 string::npos
  • 成员函数find_first_of()
string s1("hello world");
s1.find_first_of("abcd");    // 10
//在s1中从前向后查找 “abcd” 中任何一个字符第一次出现的地方
//如果找到, 返回找到字母的位置; 如果找不到, 返回 string::npos
  • 成员函数find_last_of()
string s1("hello world");
s1.find_last_of(“abcd");
//在s1中查找 “abcd” 中任何一个字符最后一次出现的地方
//如果找到, 返回找到字母的位置; 如果找不到, 返回 string::npos
  • 成员函数find_first_not_of()
string s1("hello world");
s1.find_first_not_of("abcd");   // 0
//在s1中从前向后查找不在 “abcd” 中的字母第一次出现的地方
//如果找到, 返回找到字母的位置; 如果找不到, 返回 string::npos
  • 成员函数 find_last_not_of()
string s1("hello world");
s1.find_last_not_of("abcd");   // 9
//在s1中从后向前查找不在 “abcd” 中的字母第一次出现的地方
//如果找到, 返回找到字母的位置; 如果找不到, 返回 string::npos
string s1("hello worlld");   
cout << s1.find("ll") << endl;  // 2
cout << s1.find("abc") << endl;  // 18446744073709551615
cout << s1.rfind("ll") << endl;   // 9
cout << s1.rfind("abc") << endl;  // 18446744073709551615
cout << s1.find_first_of("abcde") << endl;  // 1
cout << s1.find_first_of("abc") << endl;   // 18446744073709551615
cout << s1.find_last_of("abcde") << endl;   // 11
cout << s1.find_last_of("abc") << endl;   // 18446744073709551615
cout << s1.find_first_not_of("abcde") << endl;   // 0 
cout << s1.find_first_not_of("hello world") << endl;  // 18446744073709551615
cout << s1.find_last_not_of("abcde") << endl;  10
cout << s1.find_last_not_of("hello world") << endl;   //18446744073709551615

替换string中的字符

  • 成员函数erase()
string s1("hello worlld");
s1.erase(5);   // 去掉下标 5 及之后的字符
cout << s1;
cout << s1.length();
cout << s1.size();

输出:

hello55
  • 成员函数find()
string s1("hello worlld");
cout << s1.find("ll", 1) << endl;
cout << s1.find("ll", 2) << endl;
cout << s1.find("ll", 3) << endl;
//分别从下标1, 2, 3开始查找 “ll”
  • 成员函数replace()
string s1("hello world");
s1.replace(2, 3, “haha");  //将s1中下标2 开始的3个字符换成 “haha”
cout << s1;

输出:

hehaha world
string s1("hello world");
s1.replace(2, 3, "haha", 1,2);
cout << s1;  
//将s1中下标2 开始的3个字符
//换成 “haha” 中下标1开始的2个字符

输出:

heah world

在string中插入字符

  • 成员函数insert()
string s1(“hello world”);
string s2(“show insert”);
s1.insert(5, s2); // 将s2插入s1下标5的位置
cout << s1 << endl;
s1.insert(2, s2, 5, 3); //将s2中下标5开始的3个字符插入s1下标2的位置
cout << s1 << endl;

输出:

helloshow insert world
heinslloshow insert world

转换成C语言式`char *`字符串

  • 成员函数c_str()
string s1("hello world");
printf("%s\n", s1.c_str());
// s1.c_str() 返回传统的const char * 类型字符串
//且该字符串以 ‘\0’ 结尾

输出:

hello world
  • 成员函数data()
string s1("hello world");
const char * p1 = s1.data();
for(int i=0; i < s1.length(); i++)
    printf("%c",*(p1+i));
//s1.data() 返回一个char * 类型的字符串
//对s1 的修改可能会使p1出错。

输出:

hello world
  • 成员函数copy()
string s1("hello world");
int len = s1.length();
char * p2 = new char[len+1];
s1.copy(p2, 5, 0);
p2[5] = '\0';
cout << p2 << endl;
// s1.copy(p2, 5, 0) 从s1的下标0的字符开始,
// 制作一个最长5个字符长度的字符串副本并将其赋值给p2
// 返回值表明实际复制字符串的长度

猜你喜欢

转载自blog.csdn.net/beashaper_/article/details/80639010
今日推荐