Linux C++ 025-STL之string容器

Linux C++ 025-STL之string容器

本节关键字:Linux、C++、容器、string
相关库函数:find、rfind、replace、append、insert等

string基本概念

string是c++风格的字符串,而string本质上是一个类。

string 和 char *的区别
(1)char * 是一个指针
(2)string 是一个类 类内部封装了 char * 管理这个字符串,是一个 char * 型的容器

特点:string 类内部封装了很多成员方法
例如:查找find、拷贝copy、替换replace、插入insert
string 管理 char* 所分配的内存,不同担心复制越界和取值越界等,由类内部进行负责

string构造函数

构造函数原型:

#include <string>

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

示例:

#include <string>
//string构造
void test01()
{
    string s1;
    
    const char * str = "hello world";
    string s2(str);
    cout << "s2 = " << s2 << endl;
    
    string s3(s2);
    cout << "s3 = " << s3 << endl;
    
    string s4(6, 'a');
    cout << "s4 = " << s4 << endl;
}

总结:string 的多种构造方式没有可比性,灵活使用即可

string赋值操作

功能描述:给string字符串进行赋值
赋值的函数原型:

#include <string>

string& operator=(const char *s);		//char * 类型字符串 赋值给当前的字符串
string& operator=(const string *s);		//string 类型字符串s赋值给当前的字符串
string& operator=(char c);				//字符c赋值给当前的字符串
string& assign(const char *s);			//char * 类型字符串s赋给当前的字符串
string& assign(const char *s, int n);	//char * 类型字符串s的前n个字符赋给当前的字符串
string& assign(const string &s);		//string 类型字符串s赋给当前字符串
string& assign(int n, char c);			//用n个字符c赋给当前字符串

示例:

#include <string>
//赋值
void test01()
{
    string str1;
    str1 = "hello world";
    cout << "str1 = " << str1 << endl;
    
    string str2;
    str2 = str1;
    cout << "str2 = " << str2 << endl;
    
    string str3;
    str3 = 'a';
    cout << "str3 = " << str3 << endl;
    
    string str4;
    str4.asign("hello C++");
    cout << "str4 = " << str4 << endl;
    
    string str5;
    str6.assign("hello C++", 5);
    cout << "str5 = " << str5 << endl;
    
    string str6;
    str6.assign(atr5);
    cout << "str6 = " << str6 << endl;
    
    string str7;
    str7.assign(5, 'x');
    cout << "str7 = " << str7 << endl;
}

总结:string的赋值方式很多,operator= 这种方式是比较实用的

string字符串拼接

功能描述:实现字符串末尾拼接字符串
函数原型:

#include <string>

string& operator+=(const char* str);		//重载+=操作符
string& operator+=(const char c);			//重载+=操作符
string& operator+=(const string &str);		//重载+=操作符
string& append(const char *s);			//字符串s连接到当前字符串结尾
string& append(const char *s, int n);		//字符串s的前n个字符连接到当前字符串结尾
string& append(const string &s);			//同operator+=(const string &str);
string& append(const string &s, int pos, int n);//字符串s中从pos开始的n个字符连接到字符串结尾

示例:

//string字符串拼接操作
void test01()
{
    string str1 = "我";
    str1 += "爱玩游戏";
    cout << "str1 = " << str1 << endl;
    str1 += ':';
    cout << "str1 = " << str1 <<endl;
    
    string str2 = " LOL DNF";
    str1 += str2;
    cout << "str1 = " << str1 << endl;
    
    string str3 = "I";
    str3,append(" love ");
    cout << "str3 = " << st3 << endl;
    
    str3.append(" game abcde ", 5);
    cout << "str3 = " << st3 << endl;
    
    str3.append(str2);
    cout << "str3 = " << st3 << endl;
    
    str3.append(str2, 0, 4);
    cout << "str3 = " << st3 << endl;
}

string查找和替换

功能描述:
查找:查找指定字符串是否存在
替换:在指定的位置替换字符串
函数原型:

#include <string>

int find(const string& str, int pos = 0) const;		//查找str第一次出现的位置,从pos开始查找
int find(char *s, int pos = 0) const;				//查找s第一次出现的位置,从pos开始查找
int find(const char *s, int pis, 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 = pos) 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

示例:

//查找
void test01()
{
    string str1 = "abcdefg";
    int pos = str1.find("df");
    if(pos == -1)
    {
        cout << "未找到字符串" << endl;
    }
    else
        cout << "找到字符串,pos = " << pos << endl;
    //rfind 和 find 区别
    //rfind从右往左查找, find从左往右查找
    pos = str1.rfind("de");
    cout << "找到字符串,pos = " << pos << endl;
}
//替换
void test02()
{
    string str1 = "abcdefg";
    //从1号位置起 3个字符替换为“1111”
    str1.replace(1, 3, "1111");
    cout << "str1 = " << str1 << endl;
}

总结:
1、find查找是从左往右,rfind从右往左
2、find找到字符串后返回查找到的第一个字符位置,找不到返回-1
3、replace在替换时,要指定从哪个位置起,多少个字符,替换成什么样的字符

string字符串比较

功能描述:字符串之间的比较
比较方式:字符串比较是按字符的ASCII码进行对比
= 返回 0
> 返回 1
< 返回 -1

函数原型:

#include <string>

int compare(const string &s);	//与string 类型的字符串s比较
int compare(const char *s);	//与char * 类型的字符串s比较

示例:

#include <string>

void test01()
{
    string str1 = "hello";
    string str2 = "hello";
    string str3 = "abcde";
    
    if(str1.compare(str2) == 0)
        cout << "str1 等于 str2" << endl;
    else if(str1.compare(str2) > 0)
        cout << "str1 大于 str2" << endl;
    else if(str1.compare(str2) < 0)
        cout << "str1 小于 str2" << endl;
}

总结:字符串对比主要是用于比较两个字符串是否相等,判断谁大谁小的意义并不是很大

string字符存取

string中单个字符存取方式有两种

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

示例:

void test01()
{
    string str = "hello world";
    //通过 [] 方式取字符
    for(int i=0;i<str.size();i++)
    {
        cout << str[i] << " ";
    }
    cout << endl;
    //通过 at() 方法获取字符
    for(int i=0;i<str.size();i++)
    {
        cout << str.at(i) << " ";
    }
    cout << endl;
    //修改单个字符
    str[0] = 'x';
    cout << "str=" << str << endl;
    
    str.at(1) = 'x';
    cout << "str=" << str << endl;
}

总结:string字符串中单个字符存取有两种方式,利用 [] 或 at()

string插入和删除

功能描述:对string字符串进行插入和删除字符操作
函数原型:

string& insert(int pos, const char *s);		//从pos起插入字符串
string& insert(int pos, const string& str);
string& insert(int pos, int n, char c);		//从pos起插入n个字符c
string& erase(int pos, int n = pos);		//删除从pos起的n个字符

示例:

void test01()
{
    string str1 = "hello";
    
    str1.insert(1, "111");
    cout << "str1 = " << str1 << endl;
    
    string str2 = "world";
    str1.insert(str2);
    cout << "str1 = " << str1 << endl;
    
    str1.erase(1, 3);
    cout << "str1 = " << str1 << endl;
}

总结:插入和删除的起始下标都是从0开始。

string子串

功能描述:从字符串中回去想要的子串
函数原型:

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

示例:

void test01()
{
    string str1 = "abcdefg";
    string str2 = str1.substr(2, 3);
    cout << "str2 = " << str2 << endl;
}

//使用操作
void test02()
{
    string email = "zhangsan@sina.com";
    //从邮件地址中获取用户名信息
    int pos = email.find("@");
    cout << pos << endl;
    
    string userName = email.substr(0, pos);
    cout << userName << endl;
}

总结:灵活的运用求子串功能,可以在实际开发中获取有效的信息。到目前为止,可以得出 string 对象到底如何存储字符串的结论如下。

1、译器会为每一个 string 对象分配 24 个字节的栈空间;
2、如果要存储的字符串长度(strlen 而非 sizeof)小于等于 22,则直接存储在函数栈中;最后一个字节(地址最高处)存储字符串的实际长度;
3、如果要存储的字符串长度超过 22,会另外分配堆内存空间存储字符串本身,栈内的 24 个字节空间另有他用:
4、将字符串在堆中的地址存储在 24 个字节的前 8 个字节;
5、中间 8 个字节存储字符串的长度;
6、最后 8 个字节:地址最高的字节固定为 0x80,剩余字节存储分配的堆空间大小。

注意:以上的测试基于我当前使用的编译器,根据 StackOverflow 的一些回答,其他的编译器可能有不同的存储策略,本文暂不涉及。

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值