C++ string最全入门

STL中的string是一种特殊类型的容器,除了可以作为字符类型的容器外,更多的是作为一种数据类型----字符串,可以像int,double之类的基本数据类型那样定义string类型的数据,并进行各种运算。此外,string具有字符串的查找,替换,取子串,插入子串等处理能力。

1.string对象的定义和初始化

string c; //定义字符串c,不含任何字符。

string c1("this is a string"); //定义字符串c1,并用指定字符串初始化其内容

string c2=c1; //定义自付出c2,并用c1初始化它

string s[10]; //定义字符串数组,能够保存10个字符串,相当于char[ ][ ];

string s(5,'c'); //定义s,用5个‘c’,即“ccccc”初始化;

2.string类型的赋值

string类型的赋值操作与int等基本类型的赋值操作相同,不必用strcpy()函数

例如:

string s1,s2,s3[3]; //定义string对象及数组

string name[3]=("tom","jerrry","duck"); //string对象数组定义与初始化

s1="this is a string"; //string赋值

s2=s1;

s3[0]=s1; //string数组元素访问

s3[1]="string arr";

3.string类型的连接

用“+”和“+=”可以对;两个string类型对象进行连接运算。例如:

string s1("I am boy"),s3;

string s2="i am come from china!";

s3=s1+","+s2;   //s3:I am boy,i come from china!

s1+=","+s2;   //s1:I am boy,i come from china!

4.string的常用函数如下:

  假设s1,s2的定义如下:

     string s1="ABCDEFH";

     string s2="0123456123";

     string s;

 string成员函数如下:

substr(n1,n) //取子串函数,从当前字符串的n1下标开始,取出n个字符。如“s=s1.substr(2,3)”的结                      //果为:s="CDE"

swap(s)  //交换字符串。如“s1.swap(s2)”的结果为:s1="0123456123" ,s2="ABCDEFH"

size()/length() //计算字符串中当前存放的字符个数。如"s1.length()"的结果为7

capacity() //计算字符串的容量(可容纳的字符个数)。"s1.capacity()"的结果为31

max_size() //计算string类型数据的最大容量。

find(s) //在当前字符串中查找子串s,如果找到就返回s在当前串中的起始位置.如果没有找到,返回常数string::npos.如"s1.find("EF")"的结果为:4

rfind(s) //同find,但从后往前进行查找。如"s1.find("BCD")"的结果为:1

find_first_of(s) //在当前串中查找子串s第一次出现的位置

find_last_of(s) //在当前串中查找子串s最后一次出现的位置

replace(n1,n,s) //替换当前字符串中的字符,n1是替换的起始下标,n是要替换的字符个数,s是用来                               替换的字符串

replace(n1,n,s,n2,m) //n1是替换的起始下标,n是替换掉的字符个数,s是用来替换的字符串,n2                                        是s中用来替换的起始下标,m是s中用于替换的字符的个数.                                                              如"s1.replace(2,3,s2,2,3)"的结果为:s1="AB234FH"

insert(n,s) //在当前串的下标位置n之前,插入s串. 如“s1.insert(2,"88888”)"的结果                                               为:s1="AB88888CDEFH"

insert(n1,s,n2,m) //在当前串的n1下标后插入s串,n2是s串中要插入的起始下标,m是s串中要插                                      入的字符个数。如"s1.insert(2,s2,3,2)"的结果为:s1="AB34CDEFH"

简例:

#include<bits/stdc++.h>
using namespace std;
//typedef long long ll;

int main()
{
    string s1="中华人民共和国成立了";
    string s2="中国人民从此站起来了!";
    string s3,s4,s5;
    s3=s1+","+s2;
    int n=s1.find_first_of("人民");
    if(n!=string::npos)
        cout<<"人民在s1中的位置: "<<n<<endl;
    else
        cout<<"在s1中没有该子串!";  //npos是没有找到时的函数返回值
    s4=s1.substr(4,10); //一个汉字占两个字节
    cout<<"s1= "<<s1<<endl;
    cout<<"s2= "<<s2<<endl;
    cout<<"s3= "<<s3<<endl;
    cout<<"s4= "<<s4<<endl;
    if(s1>s2)
        cout<<"s1>s2= true"<<endl;
    else
        cout<<"s1>s2= false"<<endl;
    s3.replace(s3.find("从此"),4,"从1949年");
    cout<<"s3 after replace= "<<s3<<endl;
    s3.insert(s3.find("站"),"10月");
    cout<<"s3 after insert= "<<s3<<endl;
    return 0;
}

输出:

人民在s1中的位置: 4
s1= 中华人民共和国成立了
s2= 中国人民从此站起来了!
s3= 中华人民共和国成立了,中国人民从此站起来了!
s4= 人民共和国
s1>s2= true
s3 after replace= 中华人民共和国成立了,中国人民从1949年站起来了!
s3 after insert= 中华人民共和国成立了,中国人民从1949年10月站起来了!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值