当前位置: 首页 > article >正文

每日学习笔记:C++ STL 的forward_list

定义

特点

 

操作函数

 

 

元素查找、移除或安插

forward_list::emplace_after

arg...指的是元素构造函数的参数(0~N个)

#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 (;;);
}

forward_list::splice_after

<C++标准库第二版>书中介绍了c.splice_after(pos,c2,c2pos)的定义【c2pos所指的下一个转移到pos所指的下一个】,但是示例代码却写成了

这个调用的参数顺序与函数定义的参数顺序并不一致,于是我专门验证了一下,发现这个写法的运行结果与按照函数定义的参数顺序t2.splice_after(pos2, t1, pos1);运行结果居然相同,甚至我改成了下面这样的调用,结果仍然相同

forward_list<int> t3; //定义一个空的forward_list
t3.splice_after(pos2, forward_list<int>(), pos1); //形参传入一个空的forward_list

细看了一下 splice_after函数实现发现,在没有开启DEBUG宏的情况下,其内部并没有操作形参传入的forward_list参数,而只是对迭代器pos2、pos1之右(后)所指内容进行了拼接。即常规的单向链表拼接的指针操作。

示例代码:

#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 (;;);
}


http://www.kler.cn/a/272332.html

相关文章:

  • 云原生周刊:K8s 生产环境架构设计及成本分析
  • 关于机器学习的一份总结
  • 论文阅读笔记:AI+RPA
  • 【Leetcode 热题 100】70. 爬楼梯
  • java基础概念59-File
  • Spring自定义BeanPostProcessor实现bean的代理Java动态代理知识
  • 【C语言】内存函数~
  • vb.net+zxing.net随机彩色二维码、条形码
  • 【学习笔记】云原生的关键技术初步
  • Puppet 代码入门:清单和模块
  • 2024 年(第 12 届)“泰迪杯”数据挖掘挑战赛——B 题:基于多模态特征融合的图像文本检索完整思路与源代码分享
  • 【Java初阶(一)】初识Java
  • 测试人员Bug书写规范
  • 【递归搜索回溯专栏】专题二:二叉树中的深搜----二叉树剪枝
  • 24计算机考研调剂 | 武汉科技大学
  • 安全架构设计
  • 静默安装OGG21.3微服务版本FOR ORACLE版本
  • [java基础揉碎]断点调试
  • 多核(CPU)系统中并行计算Atomic原子操作与缓存一致性(memory/cache coherency)
  • C++/CLI学习笔记5(快速打通c++与c#相互调用的桥梁)
  • Linux基础开发工具之yum与vim
  • golang常用库之-golang常用库之-ladon包 | 基于策略的访问控制
  • C++ 接口的实现,及作用通俗理解方式
  • DevOps 环境预测测试中的机器学习
  • MySQL主从数据库简单搭建
  • 谈谈对数据库索引的认识