stl常用容器-string
C++标准库定义了一种string类,定义在头文件<string>
string封装了很多使用的办法:
查找find,拷贝copy,删除delete,替换replace,插入insert
不用考虑内存释放和越界,string管理char*分配的内存,每一次的string调用都由string类来处理,不用担心复制,越界和取值越界的问题
构造函数
string();//创建一个空的字符串 例如: string str;
string(const string& str);//使用一个string对象初始化另一个string对象
string(const char* s);//使用字符串s初始化
string(int n, char c);//使用n个字符c初始化
基本赋值操作
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方法获取字符
这里如果采用[]来获取的话当访问越界的时候直接停止,如果采用at方法来处理就会返回一个异常
拼接操作
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
查找和替换
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
rfind是从右往左查找,find是从左往右查找。
比较
/*
compare函数在>时返回 1,<时返回 -1,==时返回 0。
比较区分大小写,比较时参考字典顺序,排越前面的越小。
大写的A比小写的a小。
*/
int compare(const string &s) const;//与字符串s比较
int compare(const char *s) const;//与字符串s比较
子串
string substr(int pos = 0, int n = npos) const;//返回由pos开始的n个字符组成的字符串
插入和删除
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);
const char *可以隐式的转换为string
但是string不能隐式转换为const char*
案例:分割字符串
#include<iostream>
#include<string>
#include<vector>
using namespace std;
void main()
{
string temp[3];
string a = "www.baidu.com";
vector<string>b;//用b来存储分隔开的字符串
int pos;
pos = a.find(".");
temp[0] = a.substr(0, pos);
a = a.substr(pos+1, a.size());
pos = a.find(".");
temp[1] = a.substr(0, pos);
a = a.substr(pos+1, a.size());
temp[2] = a;
for (int i = 0; i < 3; i++)
{
b.push_back(temp[i]);
cout << temp[i] << endl;
}
}
//C语言版
//将小写字母全部转为大写字母
#include<iostream>
#include<stdio.h>
#include<string>
#include<vector>
using namespace std;
void main()
{
string k = "asdasASDasdASD";
const char* p = k.c_str();
char* pp = (char*)p;
for (int i = 0; i < k.size(); i++)
{
if (pp[i] >= 97)
{
pp[i] -= 32;
}
}
printf("%s\n", pp);
}
//直接采用库函数
#include<iostream>
#include<stdio.h>
#include<string>
#include<vector>
using namespace std;
void main()
{
string k = "asdasASDasdASD";
for (int i = 0; i < k.size(); i++)
{
str[i]=toupper(str[i]);
}
cout<<p<<endl;
}