前言
在学习string类的过程中,我发现了assign这个函数,感觉很有用,就来记录一下
assign函数原型:
void assign(size_type n, const T& x = T()); void assign(const_iterator first, const_iterator last);
assign函数有两种使用方式:
第一种:容器名.assign (a, b);
容器名.assign (a, b);
将vector中的内容清空,并给予a个b元素
下面给出一个例子:
#include<iostream> #include<vector> using namespace std; int main() { vector<int>v1{ 1,2,3 }; //创建一个容器v1 元素类型是int 有三个元素 v1.assign(2, 5); for (int val : v1) { cout << val << endl; } cout << "--------------------" << endl; v1.assign(4, 5); for (int val : v1) { cout << val << endl; } cout << "--------------------" << endl; int a = 2; int b = 3; int n = a * b; int x; v1.assign(n, x); for (int val : v1) { cout << val << endl; } cout << "--------------------" << endl; return 0; }
通过上面这个例子,我们可以发现,首先,在传入新的元素之前,assign函数会先清空vector中的内容,之后,再传入新的数据,并且,无论是传入一个变量,还是传入未初始化的变量,都可以实现assign的功能
注意:第一个元素,即要传入的元素个数不能是未初始化的变量,不然程序会报错
第二种:容器名2.assign(容器名1.begin(),容器名1.end());
容器名2.assign(容器名1.begin(),容器名1.end());
提示:
这种使用方法的含义就是:
将容器1中的begin()和end()之间的元素放到容器2中,包含起始位置和终止位置。同样的,也是先清空容器2中的内容
下面给出一个例子:
#include<iostream> #include<vector> using namespace std; int main() { vector<int>v1{ 1,2,3 }; vector<int>v2{ 1,2 }; v2.assign(v1.begin(), v1.end()); for (int val : v2) { cout << val << endl; } cout << "--------------" << endl; v2.assign(v1.begin() + 1, v1.end() - 1); for (int val : v2) { cout << val << endl; } cout << "--------------" << endl; return 0; }
通过上面这些例子,相信我们就可以基本明白assign是如何使用的了
at函数
函数源码
vector<_Tp, _Allocator>::at(size_type __n) { if (__n >= size()) this->__throw_out_of_range(); return this->__begin_[__n]; }
了解即可,不用深究
at函数的使用
arr[3]与arr.at(3)的效果是一样的,只是使用at函数,不会发生越界访问的情况,更加安全
举个例子:
#include<iostream> #include<vector> #include<algorithm> using namespace std; int main() { vector<int>arr{ 1,2,3,4,5 }; for (int i = 0; i < arr.size(); i++) { cout << arr.at(i) << endl; } //cout << arr.at(5) << endl; return 0; }
运行结果:
相信通过上面的学习,我们已经明白了如何使用at函数
append函数
接下来,我们来学习append函数
用法1:完全复制
格式:
append函数的使用格式:
字符串1.append(字符串2);
例子:
下面,举一个例子,方便大家理解:
#include<iostream> using namespace std; int main() { string a = "qaz"; string b = "wsx"; string c = "edc"; cout << a << endl; a.append(b); cout << a << endl; a.append(b + c); cout << a; return 0; }
运行结果:
通过上面这个例子,我们可以知道虽然append函数一次只能复制一个字符串,但这个字符串是可以先运算的,比如:b+c
用法2:部分复制(后面的字符)
append除了复制全部内容以外,还可以选取部分进行复制
格式:
使用格式:
字符串1.append(字符串2,起始位置index,复制元素个数n);
作用:
将字符串2中第index个位置开始(包含起始位置的元素),共n个元素,拷贝到字符串1的末尾
例子:
下面给出一段代码,方便大家理解:
#include<iostream> using std::string; using std::cout; using std::endl; int main() { string a = "hello"; string b = "world"; cout << a << endl; a.append(b, 2, 3); cout << a << endl; return 0; }
运行结果:
特别的:
当只传入起始位置index,而不传入复制元素个数n的时候,编译器默认拷贝到字符串末尾
用法3:部分复制(前面的字符)
格式:
字符串1.append(C语言风格的字符串2,复制元素的个数n);
将字符串2中从开始位置算起,共复制n个元素放到字符串1的末尾
例子:
#include<iostream> using namespace std; int main() { string a = "hello"; const char* b = "world"; a.append(b, 3); cout << a << endl; return 0; }
运行结果:
注意:
当直接传入字符串的时候,编译器默认它是C语言风格的字符串
例子如下:
#include<iostream> using namespace std; int main() { string a = "hello"; a.append("world", 5); cout << a << endl; return 0; }
用法4:复制相同字符
格式:
字符串1.append(复制字符的个数n,复制的字符ch);
作用:
将n个ch复制到字符串1的后面
例子:
#include<iostream> using namespace std; int main() { string a = "hello"; char c = '!'; a.append(3, c); cout << a << endl; int n = 4; a.append(n, 'h'); cout << a << endl; return 0; }
运行结果:
结语
对于assign、at和append函数的学习和介绍到这里就结束了,希望这篇文章对你有帮助,我们下次见~