#include <iostream>
#include <string>
using namespace std; // 初始化
void test01()
{
string s1; // 调用无参构造 创建一个空的字符串
string s2(, 'c'); // 使用 n 个字符 c 初始化
string s3("abcdefg"); // 使用字符串初始化
string s4(s3); // 使用一个 string 对象初始化另一个 string 对象(拷贝构造)
cout << s1 << endl;
cout << s2 << endl;
cout << s3 << endl;
cout << s4 << endl;
cout << "-----------------" << endl;
} // 赋值操作
// string& operator=(const char* s);//char*类型字符串 赋值给当前的字符串
// string& operator=(const string &s);//把字符串 s 赋给当前的字符串
// string& operator=(char c);//字符赋值给当前的字符串
// string& assign(const char *s);//把字符串 s 赋给当前的字符串
// string& assign(const char *s, int n);//把字符串 s 的前 n 个字符赋给当前的字符串
// string& assign(const string &s);//把字符串 s 赋给当前字符串
// string& assign(int n, char c);//用 n 个字符 c 赋给当前字符串
// string& assign(const string &s, int start, int n);//将 s 从 start 开始 n 个字符赋值给字符串
void test02()
{
string s1;
string s2("appp");
s1 = "abcdef";
cout << s1 << endl;
s1 = s2;
cout << s1 << endl;
s1 = 'a';
cout << s1 << endl;
// 成员方法assign
s1.assign("jkl");
cout << s1 << endl;
cout << "-----------------" << 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;
try
{
// cout << s1[100] << endl;
cout << s1.at() << endl;
}
catch (...)
{
cout << "越界" << endl;
}
cout << "-----------------" << endl;
// 区别:[]方式如果访问越界,就直接挂了
// at方式 访问越界会抛出异常out_of_range
} // 拼接操作
// string& operator+=(const string& str);//重载+=操作符
// string& operator+=(const char* str);//重载+=操作符
// string& operator+=(const char c);//重载+=操作符
// string& append(const char *s);//把字符串 s 连接到当前字符串结尾
// string& append(const char *s, int n);//把字符串 s 的前 n 个字符连接到当前字符串结尾
// string& append(const string &s);//同 operator+=()
// string& append(const string &s, int pos, int n);//把字符串 s 中从 pos 开始的 n 个字符连接到当前字符串结尾
// string& append(int n, char c);//在当前字符串结尾添加 n 个字符 c
void test04()
{
string s = "abcd";
string s2 = "";
s += "abcd";
s += s2;
cout << s << endl;
string s3 = "";
s2.append(s3);
cout << s2 << endl;
string s4 = s2 + s3;
cout << s4 << endl;
cout << "-----------------" << endl;
} // 查找操作
// int find(const string& str, int pos = 0) const; //查找 str 第一次出现位置,从 pos 开始查找
// int find(const char* s, int pos = 0) const; //查找 s 第一次出现位置,从 pos 开始查找
// int find(const char* s, int pos, int n) const; //从 pos 位置查找 s 的前 n 个字符第一次位置
// int find(const char c, int pos = 0) const; //查找字符 c 第一次出现位置
// int rfind(const string& str, int pos = npos) const;//查找 str 最后一次位置,从 pos 开始查找
// int rfind(const char* s, int pos = npos) const;//查找 s 最后一次出现位置,从 pos 开始查找
// int rfind(const char* s, int pos, int n) const;//从 pos 查找 s 的前 n 个字符最后一次位置
// int rfind(const char c, int pos = 0) const; //查找字符 c 最后一次出现位置
void test05()
{
string s = "abcdefgffffghijkl";
// 查找第一次出现的位置
int pos = s.find("fg");
cout << "pos: " << pos << endl;
// 查找最后一次出现的位置
pos = s.rfind("fg");
cout << "pos: " << pos << endl;
cout << "-----------------" << endl;
} // string替换
// string& replace(int pos, int n, const string& str); //替换从 pos 开始 n 个字符为字符串 str
// string& replace(int pos, int n, const char* s); //替换从 pos 开始的 n 个字符为字符串 s
void test06()
{
string s = "abcdefg";
s.replace(, , "");
cout << s << endl;
cout << "-----------------" << endl;
} // string 比较
/* compare 函数在>时返回 1,<时返回 -1,==时返回 0。比较区分大小写,比较时参考字典顺序,排越前面的越小。大写的 A 比小写的 a 小。 */
// int compare(const string &s) const; //与字符串 s 比较
// int compare(const char *s) const;//与字符串 s 比较
void test07()
{
string s1 = "abcd";
string s2 = "abce";
if (s1.compare(s2) == )
{
cout << "字符串相等!" << endl;
}
else
{
cout << "字符串不相等!" << endl;
}
cout << "-----------------" << endl;
} // 子串操作
// string substr(int pos = 0, int n = npos) const;//返回由 pos 开始的 n 个字符组成的字符串
void test08()
{
string s = "abcdefg";
string mySubstr = s.substr(, );
cout << mySubstr << endl;
cout << "-----------------" << endl;
} // 插入和删除
// string& insert(int pos, const char* s); //插入字符串
// string& insert(int pos, const string& str); //插入字符串
// string& insert(int pos, int n, char c);//在指定位置插入 n 个字符c
// string& erase(int pos, int n = npos);//删除从 Pos 开始的 n 个字符
void test09()
{
string s = "abcdefg";
s.insert(, "");
cout << s << endl;
s.erase(, );
cout << s << endl;
} int main()
{
test01();
test02();
test03();
test04();
test05();
test06();
test07();
test08();
test09();
getchar();
return ;
}
 //string 转 char*
string str = "itcast";
const char* cstr = str.c_str();
//char* 转 string
char* s = "itcast";
string sstr(s);

C++ STL 之 string的更多相关文章

  1. STL的string和wstring

    STL有字符串处理类——stirng和wstring,但是用的时候会觉得不是很方便,因为它不能像TCHAR一样根据定义的宏在char类型字符串和wchar_t进行转换,总不能因为程序要Unicode就 ...

  2. C++之STL之string

    /*C 语言中字符数组一般会采用char str[]来存放,但是显得会比较麻烦,C++在stl中加入了string类型,对字符串常用的功能进行了封装,操作起来比较方便*/#include<cst ...

  3. POJ 3096 Surprising Strings(STL map string set vector)

    题目:http://poj.org/problem?id=3096 题意:给定一个字符串S,从中找出所有有两个字符组成的子串,每当组成子串的字符之间隔着n字符时,如果没有相同的子串出现,则输出 &qu ...

  4. C++STL之string (转)

    在学习c++STL中的string,在这里做个笔记,以供自己以后翻阅和初学者参考. 1:string对象的定义和初始化以及读写 string s1;      默认构造函数,s1为空串 string ...

  5. C++STL之String

    本文直接转载,非原创!仅记录供自己学习之用. 出处:http://blog.csdn.net/y990041769/article/details/8763366 在学习c++STL中的string, ...

  6. STL 的string类怎么啦?

    前言   上个周末在和我的同学爬香山闲聊时,同学说到STL中的string类曾经让他备受折磨,几年前他开发一个系统前对string类还比较清楚,然后随着程序的复杂度的加深,到了后期,他几乎对strin ...

  7. STL之string使用简介

    声明一个C++字符串 string类的构造函数和析构函数如下: string s; //生成一个空字符串s string s(str) //拷贝构造函数 生成str的复制品 string s(str, ...

  8. STL:string类中size()与length()的区别

    结论是:两者没有任何区别 解释: C++Reference中对于两者的解释: 两者的具体解释都一模一样: 理解: length是因为C语言的习惯而保留下来的,string类最初只有length,引进S ...

  9. C++ STL介绍——String类

    目录 1.简介 2.string类成员函数汇总 3.String类的构造函数以及析构函数 4.获取字符串长度 5.获取字符串元素 6.字符串比较方法 7.字符串输入输出 8.字符串查找函数 1.简介 ...

  10. 【STL】string 常用函数

    string类的构造函数: string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 此外,string类还支持默认构造 ...

随机推荐

  1. numpy中flatten学习笔记

    ndarray.flatten() 用法 用于返回一个折叠成一维的数组.该函数只能适用于numpy对象,即array或者mat,普通的list列表是不行的. 例子 # coding=utf-8 fro ...

  2. 朴素贝叶斯算法python实现

    朴素贝叶斯是一种十分简单的分类算法,称其朴素是因为其思想基础的简单性,就文本分类而言,他认为词袋中的两两词之间的关系是相互独立的,即一个对象的特征向量中的每个维度都是互相独立的.这是朴素贝叶斯理论的思 ...

  3. MySQL、sqlalchemy、pymysql、mysqldb、DBAPI之间关系梳理(终于明白了)

    MySQL.sqlalchemy.pymysql.mysqldb.DBAPI之间关系梳理(终于明白了) python3不再支持mysqldb 请用pymysql和mysql.connector 问题背 ...

  4. 阿里云服务器怎么用ip访问不了

    个人想做个网站,就买了个阿里云服务器,不得不说阿里的安全做的很好,但是对于我这种小白,就成了麻烦了 工具/原料   阿里云服务器 方法/步骤     首先百度搜索阿里云,进入登录界面,输入账号密码登录 ...

  5. 07-08 Flutter仿京东商城项目 商品分类页面布局:Flutter仿京东商城项目 商品分类页面数据渲染

    Flutter实战(交流群:452892873) 本项目是一个实战项目,根据目录建文件,并复制从第一节到最新更新的文章,可以构成完整的一个请求后台数据的项目: CateModel.dart class ...

  6. Qt编写数据可视化大屏界面电子看板9-曲线效果

    一.前言 为了编写数据可视化大屏界面电子看板系统,为了能够兼容Qt4和嵌入式linux系统,尤其是那种主频很低的,但是老板又需要在这种硬件上(比如树莓派.香橙派.全志H3.imx6)展示这么华丽的界面 ...

  7. SyncToy

    • synchronize :在这个模式下,SyncToy会使得两个文件夹完全一致,无论在哪一个文件夹中操作,对应的操作相当于都在另一个文件夹中执行了一次.(也就是我们所说的“同步”).• echo: ...

  8. 申请 Let's Encrypt 通配符 HTTPS 证书

    目录 一.背景知识 1.1.什么是通配符证书 1.2.什么是 Let's Encrypt 二.证书申请(certbot) 2.1.系统确定 2.2.工具安装 2.3.证书申请 2.4.证书查看 2.5 ...

  9. webdriervAPI(获取验证信息)

    from  selenium  import  webdriver driver  =  webdriver.Chorme() driver.get("http://www.baidu.co ...

  10. 最新 鹏博士java校招面经 (含整理过的面试题大全)

    从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.鹏博士等10家互联网公司的校招Offer,因为某些自身原因最终选择了鹏博士.6.7月主要是做系统复习.项目复盘.LeetCo ...