SiriBlog

siriyang的个人博客


  • 首页

  • 排行榜

  • 标签115

  • 分类37

  • 归档320

  • 关于

  • 搜索

C/CPP参考文档:C++ String

发表于 2020-01-12 更新于 2021-10-29 分类于 计算机 , 技术 , C/C++ 阅读次数: Valine:
本文字数: 12k 阅读时长 ≈ 11 分钟

C/C++参考文档

概念

  String是C++下封装的字符串对象,可实现字符串相关操作。

头文件

1
#include <string>

名字空间

1
std

构造函数(Constructors)

语法:

1
2
3
4
5
6
string();
string( size_type length, char ch );
string( const char *str );
string( const char *str, size_type length );
string( string &str, size_type index, size_type length );
string( input_iterator start, input_iterator end );

  字符串的构造函数创建一个新字符串,包括:

  • 以length为长度的ch的拷贝(即length个ch)
  • 以str为初值 (长度任意),
  • 以index为索引开始的子串,长度为length, 或者
  • 以从start到end的元素为初值。
      例如,
1
2
3
4
5
6
string str1( 5, 'c' );
string str2( "Now is the time..." );
string str3( str2, 11, 4 );
cout << str1 << endl;
cout << str2 << endl;
cout << str3 << endl;

  显示

1
2
3
ccccc
Now is the time...
time

操作符(Operators)

语法:

1
2
3
4
5
6
7
8
9
==
>
<
>=
<=
!=
+
+=
[]

  你可以用 ==, >, <, >=, <= 和 !=比较字符串。 可以用 + 或者 += 操作符连接两个字符串, 并且可以用[]获取特定的字符。


常用函数

append

语法:

1
2
3
4
5
6
basic_string &append( const basic_string &str );
basic_string &append( const char *str );
basic_string &append( const basic_string &str, size_type index, size_type len );
basic_string &append( const char *str, size_type num );
basic_string &append( size_type num, char ch );
basic_string &append( input_iterator start, input_iterator end );

  append() 函数可以完成以下工作:

  • 在字符串的末尾添加str,
  • 在字符串的末尾添加str的子串,子串以index索引开始,长度为len
  • 在字符串的末尾添加str中的num个字符,
  • 在字符串的末尾添加num个字符ch,
  • 在字符串的末尾添加以迭代器start和end表示的字符序列。
      例如以下代码:
1
2
3
string str = "Hello World";
str.append( 10, '!' );
cout << str << endl;

  显示

1
Hello World!!!!!!!!!!

assign

语法:

1
2
3
4
5
basic_string &assign( const basic_string &str );
basic_string &assign( const char *str );
basic_string &assign( const char *str, size_type num );
basic_string &assign( const basic_string &str, size_type index, size_type len );
basic_string &assign( size_type num, char ch );

  函数以下列方式赋值:

  • 用str为字符串赋值,
  • 用str的开始num个字符为字符串赋值,
  • 用str的子串为字符串赋值,子串以index索引开始,长度为len
  • 用num个字符ch为字符串赋值。
      例如以下代码:
1
2
3
string str1, str2 = "War and Peace";
str1.assign( str2, 4, 3 );
cout << str1 << endl;

  显示

1
and

at

语法:

1
reference at( size_type index );

  at()函数返回一个引用,指向在index位置的字符。 如果index不在字符串范围内, at() 将报告”out of range“错误,并抛出out_of_range异常。 比如下列代码:

1
2
string text = "ABCDEF";
char ch = text.at( 2 );

  显示字符 ‘C‘。


begin

语法:

1
iterator begin();

  begin()函数返回一个迭代器,指向字符串的第一个元素。


c_str

语法:

1
const char *c_str();

  c_str()函数返回一个指向正规C字符串的指针, 内容与本字符串相同。


capacity

语法:

1
size_type capacity();

  capacity()函数返回在重新申请更多的空间前字符串可以容纳的字符数。 这个数字至少与 size()一样大。


compare

语法:

1
2
3
4
5
6
int compare( const basic_string &str );
int compare( const char *str );
int compare( size_type index, size_type length, const basic_string &str );
int compare( size_type index, size_type length, const basic_string &str, size_type index2,
size_type length2 );
int compare( size_type index, size_type length, const char *str, size_type length2 );

  compare()函数以多种方式比较本字符串和str,返回:

返回值 情况
小于零 this < str
零 this == str
大于零 this > str

  不同的函数:

  • 比较自己和str,
  • 比较自己的子串和str,子串以index索引开始,长度为length
  • 比较自己的子串和str的子串,其中index2和length2引用str,index和length引用自己
  • 比较自己的子串和str的子串,其中str的子串以索引0开始,长度为length2,自己的子串以index开始,长度为length

copy

语法:

1
size_type copy( char *str, size_type num, size_type index );

  copy()函数拷贝自己的num个字符到str中(从索引index开始)。返回值是拷贝的字符数。


data

语法:

1
const char *data();

  data()函数返回指向自己的第一个字符的指针。


empty

语法:

1
bool empty();

  如果字符串为空则empty()返回真(true),否则返回假(false)。


end

语法:

1
iterator end();

  end()函数返回一个迭代器,指向字符串的末尾(最后一个字符的下一个位置)。


erase

语法:

1
2
3
iterator erase( iterator pos );
iterator erase( iterator start, iterator end );
basic_string &erase( size_type index = 0, size_type num = npos );

  erase()函数可以:

  • 删除pos指向的字符, 返回指向下一个字符的迭代器,
  • 删除从start到end的所有字符, 返回一个迭代器,指向被删除的最后一个字符的下一个位置
  • 删除从index索引开始的num个字符, 返回*this。

  参数index 和 num 有默认值, 这意味着erase()可以这样调用:只带有index以删除index后的所有字符,或者不带有任何参数以删除所有字符。 例如:

1
2
3
4
5
6
7
8
9
10
11
string s("So, you like donuts, eh? Well, have all the donuts in the world!");
cout << "The original string is '" << s << "'" << endl;

s.erase( 50, 14 );
cout << "Now the string is '" << s << "'" << endl;

s.erase( 24 );
cout << "Now the string is '" << s << "'" << endl;

s.erase();
cout << "Now the string is '" << s << "'" << endl;

  将显示

1
2
3
4
The original string is 'So, you like donuts, eh? Well, have all the donuts in the world!'
Now the string is 'So, you like donuts, eh? Well, have all the donuts'
Now the string is 'So, you like donuts, eh?'
Now the string is ''

find

语法:

1
2
3
4
size_type find( const basic_string &str, size_type index );
size_type find( const char *str, size_type index );
size_type find( const char *str, size_type index, size_type length );
size_type find( char ch, size_type index );

  find()函数:

  • 返回str在字符串中第一次出现的位置(从index开始查找)。如果没找到则返回string::npos,
  • 返回str在字符串中第一次出现的位置(从index开始查找,长度为length)。如果没找到就返回string::npos,
  • 返回字符ch在字符串中第一次出现的位置(从index开始查找)。如果没找到就返回string::npos

  例如,

1
2
3
4
5
6
string str1( "Alpha Beta Gamma Delta" );
unsigned int loc = str1.find( "Omega", 0 );
if( loc != string::npos )
cout << "Found Omega at " << loc << endl;
else
cout << "Didn't find Omega" << endl;

find_first_of

语法:

1
2
3
4
size_type find_first_of( const basic_string &str, size_type index = 0 );
size_type find_first_of( const char *str, size_type index = 0 );
size_type find_first_of( const char *str, size_type index, size_type num );
size_type find_first_of( char ch, size_type index = 0 );

  find_first_of()函数:

  • 查找在字符串中第一个与str中的某个字符匹配的字符,返回它的位置。搜索从index开始,如果没找到就返回string::npos
  • 查找在字符串中第一个与str中的某个字符匹配的字符,返回它的位置。搜索从index开始,最多搜索num个字符。如果没找到就返回string::npos,
  • 查找在字符串中第一个与ch匹配的字符,返回它的位置。搜索从index开始。

find_first_not_of

语法:

1
2
3
4
size_type find_first_not_of( const basic_string &str, size_type index = 0 );
size_type find_first_not_of( const char *str, size_type index = 0 );
size_type find_first_not_of( const char *str, size_type index, size_type num );
size_type find_first_not_of( char ch, size_type index = 0 );

  find_first_not_of()函数:

  • 在字符串中查找第一个与str中的字符都不匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops
  • 在字符串中查找第一个与str中的字符都不匹配的字符,返回它的位置。搜索从index开始,最多查找num个字符。如果没找到就返回string::nops
  • 在字符串中查找第一个与ch不匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops

find_last_of

语法:

1
2
3
4
size_type find_last_of( const basic_string &str, size_type index = npos );
size_type find_last_of( const char *str, size_type index = npos );
size_type find_last_of( const char *str, size_type index, size_type num );
size_type find_last_of( char ch, size_type index = npos );

  find_last_of()函数:

  • 在字符串中查找最后一个与str中的某个字符匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops
  • 在字符串中查找最后一个与str中的某个字符匹配的字符,返回它的位置。搜索从index开始,最多搜索num个字符。如果没找到就返回string::nops
  • 在字符串中查找最后一个与ch匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops

find_last_not_of

语法:

1
2
3
4
size_type find_last_not_of( const basic_string &str, size_type index = npos );
size_type find_last_not_of( const char *str, size_type index = npos);
size_type find_last_not_of( const char *str, size_type index, size_type num );
size_type find_last_not_of( char ch, size_type index = npos );

  find_last_not_of()函数:

  • 在字符串中查找最后一个与str中的字符都不匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops
  • 在字符串中查找最后一个与str中的字符都不匹配的字符,返回它的位置。搜索从index开始,最多查找num个字符如果没找到就返回string::nops
  • 在字符串中查找最后一个与ch不匹配的字符,返回它的位置。搜索从index开始。如果没找到就返回string::nops

get_allocator

语法:

1
allocator_type get_allocator();

  get_allocator()函数返回本字符串的配置器。


insert

语法:

1
2
3
4
5
6
7
8
iterator insert( iterator i, const char &ch );
basic_string &insert( size_type index, const basic_string &str );
basic_string &insert( size_type index, const char *str );
basic_string &insert( size_type index1, const basic_string &str, size_type index2, size_type num );
basic_string &insert( size_type index, const char *str, size_type num );
basic_string &insert( size_type index, size_type num, char ch );
void insert( iterator i, size_type num, const char &ch );
void insert( iterator i, iterator start, iterator end );

  insert()函数的功能非常多:

  • 在迭代器i表示的位置前面插入一个字符ch,
  • 在字符串的位置index插入字符串str,
  • 在字符串的位置index插入字符串str的子串(从index2开始,长num个字符),
  • 在字符串的位置index插入字符串str的num个字符,
  • 在字符串的位置index插入num个字符ch的拷贝,
  • 在迭代器i表示的位置前面插入num个字符ch的拷贝,
  • 在迭代器i表示的位置前面插入一段字符,从start开始,以end结束。

length

语法:

1
size_type length();

  length()函数返回字符串的长度。 这个数字应该和size()返回的数字相同。


max_size

语法:

1
size_type max_size();

  max_size()函数返回字符串能保存的最大字符数。


rbegin

语法:

1
const reverse_iterator rbegin();

  rbegin()返回一个逆向迭代器,指向字符串的最后一个字符。


rend

语法:

1
const reverse_iterator rend();

  rend()函数返回一个逆向迭代器,指向字符串的开头(第一个字符的前一个位置)。


replace

语法:

1
2
3
4
5
6
7
8
9
10
basic_string &replace( size_type index, size_type num, const basic_string &str );
basic_string &replace( size_type index1, size_type num1, const basic_string &str, size_type index2,
size_type num2 );
basic_string &replace( size_type index, size_type num, const char *str );
basic_string &replace( size_type index, size_type num1, const char *str, size_type num2 );
basic_string &replace( size_type index, size_type num1, size_type num2, char ch );
basic_string &replace( iterator start, iterator end, const basic_string &str );
basic_string &replace( iterator start, iterator end, const char *str );
basic_string &replace( iterator start, iterator end, const char *str, size_type num );
basic_string &replace( iterator start, iterator end, size_type num, char ch );

  replace()函数:

  • 用str中的num个字符替换本字符串中的字符,从index开始
  • 用str中的num2个字符(从index2开始)替换本字符串中的字符,从index1开始,最多num1个字符
  • 用str中的num个字符(从index开始)替换本字符串中的字符
  • 用str中的num2个字符(从index2开始)替换本字符串中的字符,从index1开始,num1个字符
  • 用num2个ch字符替换本字符串中的字符,从index开始
  • 用str中的字符替换本字符串中的字符,迭代器start和end指示范围
  • 用str中的num个字符替换本字符串中的内容,迭代器start和end指示范围,
  • 用num个ch字符替换本字符串中的内容,迭代器start和end指示范围。

  例如,以下代码显示字符串”They say he carved it himself...find your soul-mate, Homer.“

1
2
3
4
5
6
string s = "They say he carved it himself...from a BIGGER spoon";
string s2 = "find your soul-mate, Homer.";

s.replace( 32, s2.length(), s2 );

cout << s << endl;

reserve

语法:

1
void reserve( size_type num );

  reserve()函数设置本字符串的capacity 以保留num个字符空间。


resize

语法:

1
2
void resize( size_type num );
void resize( size_type num, char ch );

  resize()函数改变本字符串的大小到num, 新空间的内容不确定。也可以指定用ch填充。


rfind

语法:

1
2
3
4
size_type rfind( const basic_string &str, size_type index );
size_type rfind( const char *str, size_type index );
size_type rfind( const char *str, size_type index, size_type num );
size_type rfind( char ch, size_type index );

  rfind()函数:

  • 返回最后一个与str中的某个字符匹配的字符,从index开始查找。如果没找到就返回string::npos
  • 返回最后一个与str中的某个字符匹配的字符,从index开始查找,最多查找num个字符。如果没找到就返回string::npos
  • 返回最后一个与ch匹配的字符,从index开始查找。如果没找到就返回string::npos

  例如,在下列代码中第一次调用rfind()返回string::npos,因为目标词语不在开始的8个字符中。然而,第二次调用返回9,因为目标词语在开始的20个字符之中。

1
2
3
4
5
6
7
8
int loc;
string s = "My cat's breath smells like cat food.";

loc = s.rfind( "breath", 8 );
cout << "The word breath is at index " << loc << endl;

loc = s.rfind( "breath", 20 );
cout << "The word breath is at index " << loc << endl;

size

语法:

1
size_type size();

  size()函数返回字符串中现在拥有的字符数。


substr

语法:

1
basic_string substr( size_type index, size_type num = npos );

  substr()返回本字符串的一个子串,从index开始,长num个字符。如果没有指定,将是默认值 string::npos。这样,substr()函数将简单的返回从index开始的剩余的字符串。

  例如:

1
2
3
4
5
6
string s("What we have here is a failure to communicate");

string sub = s.substr(21);

cout << "The original string is " << s << endl;
cout << "The substring is " << sub << endl;

  显示:

1
2
The original string is What we have here is a failure to communicate
The substring is a failure to communicate

swap

语法:

1
void swap( basic_string &str );

  swap()函数把str和本字符串交换。例如:

1
2
3
4
5
string first( "This comes first" );
string second( "And this is second" );
first.swap( second );
cout << first << endl;
cout << second << endl;

  显示:

1
2
And this is second
This comes first
-------- 本文结束 感谢阅读 --------
相关文章
  • C/CPP参考文档:C I/O
  • C/C++参考文档:C Time & Date
  • C/C++参考文档:C Memory
  • C/C++参考文档:C String & Character
  • C/CPP参考文档:C++ Algorithm
觉得文章写的不错的话,请我喝瓶怡宝吧!😀
SiriYang 微信支付

微信支付

SiriYang 支付宝

支付宝

  • 本文标题: C/CPP参考文档:C++ String
  • 本文作者: SiriYang
  • 创建时间: 2020年01月12日 - 10时01分
  • 修改时间: 2021年10月29日 - 18时10分
  • 本文链接: https://blog.siriyang.cn/posts/20200112102040id.html
  • 版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处!
C/C++ 文档
X-Data数据工程基础实践(五)
X-Data数据工程基础实践(四)
  • 文章目录
  • 站点概览
SiriYang

SiriYang

努力搬砖攒钱买镜头的摄影迷
320 日志
33 分类
88 标签
RSS
GitHub E-Mail
Creative Commons
Links
  • 友情链接
  • 作品商铺

  1. 概念
  2. 构造函数(Constructors)
  3. 操作符(Operators)
  4. 常用函数
    1. append
    2. assign
    3. at
    4. begin
    5. c_str
    6. capacity
    7. compare
    8. copy
    9. data
    10. empty
    11. end
    12. erase
    13. find
    14. find_first_of
    15. find_first_not_of
    16. find_last_of
    17. find_last_not_of
    18. get_allocator
    19. insert
    20. length
    21. max_size
    22. rbegin
    23. rend
    24. replace
    25. reserve
    26. resize
    27. rfind
    28. size
    29. substr
    30. swap
蜀ICP备19008337号 © 2019 – 2025 SiriYang | 1.7m | 25:41
0%