#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. SVM算法总结

    svm算法通俗的理解在二维上,就是找一分割线把两类分开,问题是如下图三条颜色都可以把点和星划开,但哪条线是最优的呢,这就是我们要考虑的问题: 首先我们先假设一条直线为 W•X+b =0 为最优的分割线 ...

  2. JavaScript函数中的this四种绑定形式

    this的默认绑定.隐式绑定.显示绑定.new绑定 <script> //全局变量obj_value ; //1.window调用 console.log(`*************** ...

  3. JAVA 基础编程练习题31 【程序 31 数组逆序】

    31 [程序 31 数组逆序] 题目:将一个数组逆序输出. 程序分析:用第一个与最后一个交换. package cskaoyan; public class cskaoyan31 { @org.jun ...

  4. python md5验签

    import hashlib #api验签 参数按首字母排序,然后拼接clientid=123456&num=xxxx&status=1&timestamp=157319776 ...

  5. 为Django添加图片验证码

    可直接复制到Django项目中使用 # author:sunshine from django.http import HttpResponse from PIL import Image, Imag ...

  6. shell变量默认值

    ${var:-string},${var:+string},${var:=string},${var:?string} 1. ${var:-string}和${var:=string}:若变量var为 ...

  7. python网络编程----requests模块

    python访问网站可以用标准模块--urllib模块(这里省略),和requests(安装-pip install requests)模块,requests模块是在urllib的基础上进行的封装,比 ...

  8. 在 Laravel 中使用 MongoDB

     可参考:https://blog.csdn.net/weixin_38682852/article/details/80840678 环境准备 安装 MongoDB 安装 PHP-MongoDB 扩 ...

  9. shell 入门学习

    目录 shell 入门学习 注释 执行与启动 变量 语法 调试 title: shell 入门学习 date: 2019/7/16 15:47:49 toc: true --- shell 入门学习 ...

  10. POJ 1840:Eqs

    Description Consider equations having the following form: a1x13+ a2x23+ a3x33+ a4x43+ a5x53= The coe ...