#include <iostream>//等价于C语言中的#include<stdio.h>
#include <cstring>
#include <string.h>
//以上两种都是C语言的string头文件
#include <string>//真正的C++头文件
在C++中,#include<string>才是真正的C++头文件!
int main()
{
string str1 = "str1";
cout << str1 << endl;//调用构造函数
string str2;
str2 = "str2";
cout << str2 << endl;//调用拷贝构造函数
string str3 = ("str3");
cout << str3 << endl;
return 0;
}
输出结果:
string str4(4,'x);
用4个字符初始化字符串,输出结果就是xxxx
string str5("iloveyou",1,4);
表示用字符串从下标1开始的4位初始化str5(在C++中,字符串的下标也是从0开始的,跟C语言的数组一样)
所以输出结果就是love
在于C++ string 定义的字符串没有 ' \0 ' !
两者不是同类型的,string是字符串类型,而char是字符类型。
char arr[]="iloveyou";
string str5="iloveyou";
cout<<str5.size()<<endl;
cout<<str5.length()<<endl;
①C++中的string类对象会在末尾补上'\0',这是因为C++有C语言的历史包袱。因为C语言的字符串以'\0'结尾,所以为了方便在必要时将string字符串转为C类型字符串(利用 c_str 进行转换),所以string类型对象会在末尾补上一个不计入size和capacity的'\0'。
②C++中的string类对象并不会将'\0'作为结束标志,因为string类对象内部维护了一个记录自身长度的成员变量size,在输出string类对象时会根据size的大小决定输出多少个字符,而不是看'\0'的位置决定输出到哪个字符结束。
注意string类型可以直接用数组形式【】中括号访问,并且下标也是从1开始!
首先不能用C语言中的printf(%s)函数访问,因为string类型本质上并不是字符串类型。
若强行访问,输出结果就是乱码!
C++ string为我们提供访问字符串的接口——data(),c_str();
这两个函数将string类型转换为字符串类型,方便我们用printf函数打印。
int main()
{
string str1 = "str1";
cout << str1 << endl;
printf("%s\n", str1);
printf("%s\n", str1.data());
printf("%s\n", str1.c_str());
return 0;
}
输出结果
在C++中,字符串比较的规则与C语言相同。
问:“123”和“13”相比,哪个字符串大?
答:“13”更大,因为从左到右比较,字符按照ASCII码值比较,第一个字符都是‘1’,第二个字符‘3’比‘2’大,所以“13”比“123”大。
在C++中,可以cout直接输出判断字符串的比较
int main()
{
string first = "123";
string second = "13";
cout << (first < second) << endl;
cout << (first != second) << endl;
cout << (first > second) << endl;
return 0;
}
注意事项
cout << first.compare(second) << endl; 返回值为1:first-second>0 ------> first>second
返回值为-1:first-second<0 ------> first<second
返回值为0:first-second=0 ------> first=second
int main()
{
string first = "i love you,";
string second = "i miss you";
cout << first + second << endl;
return 0;
}
想要把first和second两个字符串进行相加,直接在cout里面使用加法 + !
输出结果就是:i love you,i miss you
因为上述cout直接+,只能将两个完整的字符串进行相加,太笨重,而append()函数更加灵活,可以决定连接第几位开始,且数量可以自己定。
int main()
{
string first = "i love you,";
string second = "i miss you";
cout << first + second << endl;
first.append(second);
cout << first << endl;
first.append(second, 1, 5);
cout << first << endl;
first.append(4, '1');
cout << first << endl;
first.append("i miss you", 1, 5);
cout << first << endl;
return 0;
}
输出结果:
前言:
string查找类型的函数,如果查找不到,就返回-1。
因此在查找时,一般需要判断返回值是否等于string::nops(值就是-1)
find函数从左往右查找字符串或者字符出现的位置。
rfind函数从右往左查找字符串或者字符出现的位置。
int main()
{
string first = "i love you,";
string second = "i miss you";
if (first.find('o') != -1)
{
cout << first.find('o') << endl;
}
if (first.find("love") != -1)
{
cout << first.find("love")<< endl;
}
return 0;
}
replace函数的参数一般开始是原始想要替换的下标,之后是替换字符的个数。
int main()
{
string first = "iloveyou,";
string second = "imissyou";
first.replace(1, 4,second,1,4);
cout << first << endl;
return 0;
}
输出结果就是 imissyou
int main()
{
string first = "iloveyou,";
string second = "imissyou";
first.erase(0);
cout << first << endl;
second.erase(1, 4);
cout << second << endl;
return 0;
}
第一种使用方法是删除下标0,及以后的字符(注意是后面的字符全部干掉!)
第二种是用方法是删除下标1,之后的4个字符(自定义删除的个数)
iterator容器遍历适用于任何stl库,我们只需要掌握一个方法,其他依葫芦画瓢即可。
iterator使用方法像是指针,但跟指针有区别。有同学会问了,我们直接用 [ ] 访问数组不好吗,为什么还要整个iterator,请注意 [ ] 遍历只适用于内存是连续的情况下,如果是内存不连续(比如图或者树形结构),我们必须要使用iterator进行遍历!
下标+[] 只适用于部分容器,底层物理有一定连续链式结构、树形、哈希结构等只能用迭代器。所以迭代器才是容器访问主流形态!
前者保护的是迭代器本身不能被修改,也就是it,但是这肯定是不可以的,因为我们迭代器要++遍历;
后者保护的是迭代器指向的内容不能修改,也就是*it
该函数的作用就是提取从pos位置开始,长度为len的子字符串,返回值就是提取的子字符串。
我们之前使用的cin 、 scanf 都是默认遇到空格或者回车自动停止输入,但如果我们的字符串含有空格要输入,那怎么办呢?
这时候就需要getline出马了!geiline默认遇到空格不会停止输入,只有遇到回车才会停止输入。
一般只有字符串输入空格才会使用getline。
#include<string>
#include<iostream>
int main()
{
string s;
getline(cin,s);
return 0;
}
to_string 可以将任意类型的数字转换为string类型,非常强大!
同样,stoi(stol)等都是将字符串类型转换为数字类型,其中stoi最常用。
这两个函数记忆方法也简单,to_string函数按照字面意思就是将什么变成string,而stoi其中的s就表示的是string,i 表示int类型的整数!