定义
data:image/s3,"s3://crabby-images/57fb9/57fb95c37b29963cdc0bc53e4b53b2187c8af7a4" alt=""
特点
data:image/s3,"s3://crabby-images/192e0/192e0985ed847a15b4e52db2100a3b8ff1060856" alt=""
操作函数
data:image/s3,"s3://crabby-images/26f23/26f23e672f25378fed28df4c6f7a258dac143d8d" alt=""
data:image/s3,"s3://crabby-images/7000e/7000e7d15c19d8d839f1289dc4c7444091daf5fb" alt=""
data:image/s3,"s3://crabby-images/4b8ac/4b8ac8c21fad45ab6bb6d871350c3dd55de97eb2" alt=""
data:image/s3,"s3://crabby-images/0dd22/0dd22783864bdaa5b43c89fb51a762973fccd41e" alt=""
元素查找、移除或安插
data:image/s3,"s3://crabby-images/6adaf/6adaf35316618ef707b96db083c4557a02577de6" alt=""
data:image/s3,"s3://crabby-images/66f4e/66f4e1f7f9d2d6048e4b487af42dda6576f4902e" alt=""
data:image/s3,"s3://crabby-images/4cc18/4cc180df5f5246382375cf3592b2c1be2abf0baf" alt=""
forward_list::emplace_after
data:image/s3,"s3://crabby-images/6e44c/6e44c0a85bc598abfbe703a70d7cad170d3a28b1" alt=""
**arg...**指的是元素构造函数的参数(0~N个)
cpp
#include <iostream>
#include <memory>
#include <list>
#include <forward_list>
using namespace std;
class aaa
{
public:
aaa() {
c = 666;
};
aaa(int a, int b) {
c = a + b;
};
friend std::ostream& operator << (std::ostream& o, const aaa& s) {
o << s.c;
return o;
}
private:
int c;
};
int main()
{
forward_list<aaa> t1{ {1,1},{},{2,2} };
std::copy(t1.cbegin(), t1.cend(), std::ostream_iterator<aaa>(cout, " "));
cout << endl;
t1.emplace_after(t1.before_begin(), 6, 8);
std::copy(t1.cbegin(), t1.cend(), std::ostream_iterator<aaa>(cout, " "));
cout << endl;
t1.emplace_after(t1.before_begin());
std::copy(t1.cbegin(), t1.cend(), std::ostream_iterator<aaa>(cout, " "));
cout << endl;
forward_list<int> t{ 1,2,3 };
t.emplace_after(t.before_begin(), 55);
std::copy(t.cbegin(), t.cend(), std::ostream_iterator<int>(cout, "-"));
for (;;);
}
data:image/s3,"s3://crabby-images/5236c/5236ce7378e78e22984380eaeca10692525f38dc" alt=""
forward_list::splice_after
data:image/s3,"s3://crabby-images/85e9b/85e9b817ed06b6b8b985ad933188ac1db705eeca" alt=""
<C++标准库第二版>书中介绍了c.splice_after(pos,c2,c2pos)的定义【将c2pos所指的下一个转移到pos所指的下一个】,但是示例代码却写成了
这个调用的参数顺序与函数定义的参数顺序并不一致,于是我专门验证了一下,发现这个写法的运行结果与按照函数定义的参数顺序t2.splice_after(pos2, t1, pos1);运行结果居然相同,甚至我改成了下面这样的调用,结果仍然相同
cpp
forward_list<int> t3; //定义一个空的forward_list
t3.splice_after(pos2, forward_list<int>(), pos1); //形参传入一个空的forward_list
data:image/s3,"s3://crabby-images/37e62/37e627d41ea700b2e24d1783b85ef5e43215d1dd" alt=""
细看了一下 splice_after函数实现发现,在没有开启DEBUG宏的情况下,其内部并没有操作形参传入的forward_list参数,而只是对迭代器pos2、pos1之右(后)所指内容进行了拼接。即常规的单向链表拼接的指针操作。
data:image/s3,"s3://crabby-images/2a50a/2a50a8d2bcd37c7adbdf67e15fec7a2ea70134db" alt=""
data:image/s3,"s3://crabby-images/b8616/b86169840677ab1965770a6c42a0d7888212fa9f" alt=""
示例代码:
cpp
#include <iostream>
#include <forward_list>
using namespace std;
int main()
{
forward_list<int> t1{1,2,3,4,5};
forward_list<int> t2{ 97,98,99};
auto pos1 = t1.before_begin();
for (auto pb1 = t1.begin(); pb1 != t1.end(); ++pb1,++pos1)
{
if (*pb1 == 3)
{
break;
}
}
auto pos2 = t2.before_begin();
for (auto pb2 = t2.begin(); pb2 != t2.end(); ++pb2, ++pos2)
{
if (*pb2 == 99)
{
break;
}
}
t1.splice_after(pos2, t2, pos1);
//t2.splice_after(pos2, t1, pos1);
//forward_list<int> t3;
//t3.splice_after(pos2, forward_list<int>(), pos1);
//t2.splice_after(pos2, t1, t1.before_begin());
//t2.splice_after(pos2, t1, t1.begin());
for (;;);
}