C++ STL标准模板库---string容器的概念以及简单使用

10 篇文章 0 订阅

2019/8/15
天气:晴

string容器的基本概念

C风格字符串(以空字符结尾的字符数组)太过复杂难于掌握,不适合大程序的开发,所以C++标准库定义了一种string类,定义在头文件。

String和c风格字符串对比:

Char*是一个指针,String是一个类

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

String封装了很多实用的成员方法

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

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

string容器常用操作

string构造函数

string();//创建一个空的字符串 例如: string str;      
string(const string& str);//使用一个string对象初始化另一个string对象
string(const char* s);//使用字符串s初始化
string(int n, char c);//使用n个字符c初始化 

string基本赋值操作

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个字符赋值给字符串

string存取字符操作

char& operator[](int n);//通过[]方式取字符
char& at(int n);//通过at方法获取字符

string拼接操作

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

string查找和替换

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最后一次出现位置
string& replace(int pos, int n, const string& str); //替换从pos开始n个字符为字符串str
string& replace(int pos, int n, const char* s); //替换从pos开始的n个字符为字符串s

string比较操作

/*
compare函数在>时返回 1,<时返回 -1,==时返回 0。
比较区分大小写,比较时参考字典顺序,排越前面的越小。
大写的A比小写的a小。
*/
int compare(const string &s) const;//与字符串s比较
int compare(const char *s) const;//与字符串s比较

string子串

string substr(int pos = 0, int n = npos) const;//返回由pos开始的n个字符组成的字符串

string插入和删除操作

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个字符 

string和c-style字符串转换

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

以下为自己测试代码

#include "stdafx.h"
#include <iostream>
#include <list>
#include <vector>
#include<algorithm>
#include <string>

using namespace std;

void f_stringTest01()
{
	//string构造函数
	string s1 = string();
	string s2 = string("sssss");
	char *s = "ssss";
	string s3 = string(s);
	string s4 = string(10, 'a');

	//string基本赋值操作
	s1 = s;
	s1 = s2;
	char s5 = 's';
	s1 = s5;

	s1.assign(s);
	s1.assign(s, 2);
	s1.assign(s2);
	s1.assign(5, s5);
	s1.assign(s2, 1, 4);

	//string存取字符操作
	char s6 = s1[0];
	char s7 = s1.at(0);

	//string拼接操作
	s1 += s1;
	s1 += s;
	s1 += s5;
	s1.append(s);
	s1.append(s, 2);
	s1.append(s2);
	s1.append(s2, 1, 2);
	s1.append(10, s5);
}

void f_stringTest02()
{
	//string的查找和替换
	string s = "BC";
	string ss = "AB";
	string s1 = "ABCDE";
	char *cst = "ABCDEFG";

	int po1 = s1.find(s, 0);

	int pos2 = s1.find(cst, 0);

	int pos3 = s1.find(cst, 0, 2);

	int pos5 = s1.find('C', 0);

	int pos6 = s1.rfind(s, 0);

	int pos4 = s1.rfind(cst, 0);

	int pos7 = s1.rfind(cst, 0, 2);

	int pos8 = s1.rfind('A', 0);

	s.replace(1, 2, "aa");
	s.replace(1, 2, cst);

	//string的比较
	/*
	compare函数在>时返回 1,<时返回 -1,==时返回 0。
	比较区分大小写,比较时参考字典顺序,排越前面的越小。
	大写的A比小写的a小。
	*/
	int rt1 = s.compare(ss);
	int rt2 = s.compare(cst);

	//string子串
	string s2 = s.substr(0, 2);

	//string插入和删除操作
	string s3 = s2.insert(0, cst);

	string s4 = s2.insert(0, s2);

	string s5 = s2.insert(2, 3, 'E');

	string s6 = s2.erase(0, 5);


	string s7 = "abcdefg";
	char &a = s7[2];
	char &b = s7[3];
	a = '1';
	b = '2';
	cout << s7 << endl;
	cout << (int*)s7.c_str() << endl;

	s7 = "pppppppppppppppppppppppp";

	cout << s7 << endl;
	cout << (int*)s7.c_str() << endl;

}
void f_stringTest03()
{
	string str("ABCDefgH");

	for (int i = 0; i<str.size(); i++)
	{
		//方法1
		if (str[i] >= 'a'&&str[i] <= 'z')
		{
			str[i] -= 32;			//小写转大写
		}
		else if (str[i] >= 'A'&&str[i] <= 'Z')
		{
			str[i] += 32;			//大写转小写
		}
		//方法2
		//str[i] = toupper(str[i]);	//小写转大写	  需要包含   #include<cctype>
		//str[i] = tolower(str[i]);	//大写转小写	
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值