一、string特性

string是STL的字符串类型,通常用来表示字符串。而在使用string之前,字符串通常是用char*表示的,string与char*都可以用来表示字符串。

说到string的特性,就不得不和char*类型的字符串对比:

1、char*是一个指针,string是一个类

string封装了char*,管理这个字符串,是一个char*型的容器。

2、string封装了很多实用的成员方法

查找find,拷贝copy,删除delete,替换replace,插入insert

3、不用考虑内存释放和越界

string管理char*所分配的内存,每一次string的复制,取值都由string类负责维护,不用担心复制越界和取值越界等。

4、string和char*可以相互转换,string转char*通过string提供的c_str()方法。

//string转char*
string str=“itcast”;
const char* cstr=str.c_str();
//char*转string
char* s=“itcast”;
string sstr(s);

二、string初始化、拼接、赋值、查找、替换、比较、子串、插入和删除

1、string构造函数

用string初始化字符串分两类:用“=”号就是拷贝初始化,否则就是直接初始化。

默认构造函数:
string(); //构造一个空的字符串string s1。
拷贝构造函数:
string(const string &str); //构造一个与str一样的string。如string s1(s2)。
带参数的构造函数
string(const char *s); //用字符串s初始化
string(int n,char c); //用n个字符c初始化

例子:

string s1;//初始化字符串,空字符串
string s2 = s1; //拷贝初始化,深拷贝字符串
string s3 = "I am Yasuo"; //直接初始化,s3存了字符串
string s4(, 'a'); //s4存的字符串是aaaaaaaaaa
string s5(s4); //拷贝初始化,深拷贝字符串
string s6("I am Ali"); //直接初始化
string s7 = string(, 'c'); //拷贝初始化,cccccc

2、string存取字符操作

char& operator[](int n);//通过[]方式取字符
char& at(int n);//通过at方法获取字符
//例子:
string s="itcast";
char c=s[];
c=s.at();

3、string基本赋值操作

4、string拼接

5、string查找和替换

6、string比较

7、string子串

8、string插入和删除

三、案例

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
using namespace std; //string初始化
void test01()
{
string s1;//调用无参构造,初始化字符串,空字符串
string s2(, 'a');
string s3("abcdefg");
string s4(s3); cout << s1 << endl;//空字符串
cout << s2 << endl;//aaaaaaaaaa
cout << s3 << endl;//abcdefg
cout << s4 << endl;//abcdefg
} //string赋值操作
void test02()
{
string s1;//调用无参构造,初始化字符串,空字符串
string s2("appp");
s1 = "abcdefg";
cout << s1 << endl;
s1 = s2;
cout << s1 << endl;
s1 = "a";
cout << s1 << endl; //成员方法
s1.assign("jkl");
cout << s1 << endl;
} //取值操作
void test03()
{
string s1 = "abcdefg"; //重载[]操作符
for (int i = ;i < s1.size();i++)
{
cout << s1[i] << " ";
}
cout << endl; //at成员函数
for (int i = ;i < s1.size();i++)
{
cout << s1.at(i) << " ";
}
cout << endl; //这两种方法的区别:
//[]方式 如果访问越界,直接挂了
//at方式 访问越界 抛异常out_of_range try {
cout << s1.at() << endl;
}
catch (...) {
cout << "越界!" << endl;
}
} //string拼接操作
void test04()
{
string s = "abcd";
string s2 = "";
s += "abcd";
s += s2;
cout << s << endl;//abcdabcd1111 string s3 = "";
s2.append(s3);
cout << s2 << endl;// string s4 = s2 + s3;
cout << s4 << endl;// } //string查找操作
void test05()
{
string s = "abcdefghjfgkl";
//查找第一次出现的位置
int pos = s.find("fg");
cout << "pos:" << pos << endl;//pos:5 //查找最后一次出现的位置
pos = s.rfind("fg");
cout << "pos:" << pos << endl;//pos:9
} //string替换操作
void test06()
{
string s = "abcdefg";
s.replace(, , "");
cout << s << endl;//111cdefg
} //string比较操作:
//compare函数在>时返回1,<时返回-1,==时返回0.
//比较区分大小写,比较时参考字典顺序,排越前面的越小。
//大写的A比小写的a小。
void test07()
{
string s1 = "abcd";
string s2 = "abed";
if (s1.compare(s2) == )
{
cout << "s1与s2相等" << endl;
}
else if(s1.compare(s2) > )
{
cout << "s1大于s2" << endl;
}
else
{
cout << "s1小于s2" << endl;//s1小于s2
}
} //string子串操作
void test08()
{
string s = "abcdefg";
string mysubstr = s.substr(, );
cout << mysubstr << endl;//bcd
} //string插入和删除操作
void test09()
{
string s = "abcdefg";
s.insert(, "");
cout << s << endl;//abc111defg s.erase(, );
cout << s << endl;//c111defg
} int main(void)
{
//test01();
//test02();
//test03();
//test04();
//test05();
//test06();
//test07();
//test08();
test09(); return ;
}

部分参考了:https://blog.csdn.net/zyq522376829/article/details/46792893

string容器的更多相关文章

  1. 数据结构《19》----String容器的三种实现

    一.序言 一个简单的string 容器到底是如何实现的? 本文给出了 String 的三种从易到难的实现,涉及了 reference counting, copy on write 的技术. 二.第一 ...

  2. stl string 容器的使用

    string 是基本的字符串序列容器,对应数据结构中的串,和vector<char>也类似,但功能更多 string 容器的使用 1,string 的构造函数是. string() 2,s ...

  3. 浅谈C++ STL string容器

    浅谈C++ STL string容器 本篇随笔简单讲解一下\(C++STL\)中\(string\)容器的使用方法及技巧. string容器的概念 其实\(string\)并不是\(STL\)的一种容 ...

  4. 2.2 C++STL string容器详解

    文章目录 引言 2.2.1 string的特性 2.2.2 string用法理论 2.2.2.1 string构造函数 2.2.2.2 string赋值操作 2.2.2.3 string取值操作 2. ...

  5. c++的string容器

    c++相比c的一个好处就是实现了很多的容器和泛型算法,使得程序员的工作得到了很大的化简.其中一个很有用的泛型容器就是string.string是一个类,是一个在STL里边实现好了的类,由于他的很多功能 ...

  6. C++进阶 STL(1) 第一天 [容器,算法,迭代器] string容器 vector容器 deque容器

    课程大纲 02实现基本原理 容器,算法,迭代器 教室:容器 人:元素 教室对于楼:容器 序列式容器: 容器元素在容器中的位置是由进入容器的时间和地点来决定 序列式容器 关联式容器: 教室中 按年龄排座 ...

  7. HDU 1113 Word Amalgamation (map 容器 + string容器)

    http://acm.hdu.edu.cn/showproblem.php?pid=1113 Problem Description In millions of newspapers across ...

  8. 11.string容器

    #include <iostream> //string的本质也是容器 #include <string> #include <cstdlib> using nam ...

  9. STL之string容器

    string string封装了char*,管理这个字符串,是一个char*型的容器. string的相关操作 头文件 #include<string> string构造函数 string ...

随机推荐

  1. Parquet and ORC

    http://dongxicheng.org/mapreduce-nextgen/columnar-storage-parquet-and-orc/ 相比传统的行式存储引擎,列式存储引擎具有更高的压缩 ...

  2. [Papers]Finding Advertising Keywords on Web Pages

    参考资料: Finding Advertising Keywords on Web Pages ,Wen-tau Yih,Joshua Goodman, Vitor R. Carvalho

  3. centos 下安装python3.6.2

    具体详情: http://www.cnblogs.com/vurtne-lu/p/7068521.html

  4. python爬虫之html解析Beautifulsoup和Xpath

    Beautiifulsoup Beautiful Soup 是一个HTML/XML的解析器,主要的功能也是如何解析和提取 HTML/XML 数据.BeautifulSoup 用来解析 HTML 比较简 ...

  5. iptable防火墙面试题

    第1章 (一)基础口试题 1.1 详述 iptales 工作流程以及规则过滤顺序? 1.防火墙是一层层过滤的.实际是按照配置规则的顺序从上到下,从前到后进行过滤的. 2.如果匹配上了规则,即明确表明是 ...

  6. Luogu-2495 [SDOI2011]消耗战

    虚树第一题 对于每次询问的点建立一棵虚树,然后在树上DP,一个点的答案就是这个点的父边切断的代价与所有儿子切断的代价去最小值,当然如果这个节点是资源点则必须切父边 注意在虚树上一条边的代价应该是中间所 ...

  7. sqlserver 实时同步(发布订阅)

    配置发布订阅手册 不同版本须知:https://www.sqlmanager.net/en/articles/1548 向后兼容性:参考https://docs.microsoft.com/zh-cn ...

  8. 权限【TLCL】

    用户帐户 定义在/etc/passwd 文件里面,用户组定义在/etc/group 文件里面. /etc/shadow 包含了关于用户密码的信息 文件属性: 属性 文件类型 - 一个普通文件 d 一个 ...

  9. winform获取文件路径

    1.取得控制台应用程序的根目录方法     方法1.Environment.CurrentDirectory 取得或设置当前工作目录的完整限定路径     方法2.AppDomain.CurrentD ...

  10. 【转】Android ImageView的scaleType属性与adjustViewBounds属性

    ImageView的scaleType的属性有好几种,分别是matrix(默认).center.centerCrop.centerInside.fitCenter.fitEnd.fitStart.fi ...