STL Array、ForwardList源码剖析

STL Array、ForwardList源码剖析

参考文章: https://blog.csdn.net/weixin_45389639/article/details/121618243

array 源代码

template<typename _Tp,std::size_t _Nm>
struct array
{
	typedef _Tp value_type;
	typedef _Tp* pointer;
	typedef value_type* iterator;
	// Support for zero-sized arrays mandatory
	value_type _M_instance[_Nm?_Nm:1];

	iterator begin(){return iterator(_M_instance[0]);}
	iterator end(){return iterator(_M_instance[_Nm]);}
	...
};

array的使用

array不可以扩充,必须指定大小

array<int,10> arr;
auto it = arr.begin();
//array<int,10>::iterator it = ...
it += 3;
cout << *it << endl;

array实际是个数组
在C++11中,新增的一种容器std::array,和我们平常所使用的array操作类似,和vector动态可扩容不同它是静态不可扩容的。

只要是连续空间迭代器不需要额外设计成一个class,
array的迭代器是一个指针(萃取)
在这里插入图片描述

forward_list容器

​ forward_list 也是C++11提供的容器,和list容器不同,它是单项链表,比起需要每个Node节点需要存储next和pre节点的list。forward_list只需要存储next节点,forward_list会更加轻量级。

在这里插入图片描述

相关推荐

  1. 【FastDDS剖析】定时器

    2024-04-26 19:04:07       28 阅读
  2. JVM剖析之registerNatives方法

    2024-04-26 19:04:07       32 阅读
  3. SpringBoot 原理深入及剖析

    2024-04-26 19:04:07       25 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-26 19:04:07       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-26 19:04:07       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-26 19:04:07       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-26 19:04:07       20 阅读

热门阅读

  1. 1.mysql--常用sql(2)

    2024-04-26 19:04:07       10 阅读
  2. 【C++刷题】优选算法——动态规划第五辑

    2024-04-26 19:04:07       14 阅读
  3. leetcode2418.按身高排序

    2024-04-26 19:04:07       9 阅读
  4. 虚拟机部署openeuler网络配置

    2024-04-26 19:04:07       17 阅读
  5. npm install CERT_HAS_EXPIRED解决方法

    2024-04-26 19:04:07       15 阅读
  6. BootLooder引导传参和镜像编译

    2024-04-26 19:04:07       15 阅读
  7. Git忽略文件

    2024-04-26 19:04:07       12 阅读