【C/C++ 基础 数组容器比较】深入探究C++容器:数组、vector与array之间的异同

简介: 【C/C++ 基础 数组容器比较】深入探究C++容器:数组、vector与array之间的异同
数组 vector array
访问方式 支持标准访问 支持标准访问
存储位置
复制 逐个复制

共同点

  1. vector和array是容器;
  2. 三者均可以使用下表运算符对元素进行操作,即vector和array都针对下标运算符[]进行了重载;
  3. 三者在内存的方面都使用连续内存,即在vector和array的底层存储结构均使用数组

不同点

(0.)安全性:数组是不安全的,array和vector是比较安全的(有效的避免越界等问题)

(1.)存储位置部分:std::array是在栈区分配的,它的大小在编译时已经确定,vector对象存储在堆区。数组可以存储在栈上(自动分配的数组)或堆上(使用new[]或malloc()分配的数组)。

(2.)复制部分:数组需要逐个元素复制,vector和array可以使用拷贝构造函数或赋值操作符实现整个对象的复制。

(3.)vector属于变长的容器,即可以根据数据的插入和删除重新构造容器容量;但是array和数组属于定长容器

(4.)vector提供了front()和back()以及at()访问方式,array提供了at()访问方式,使得访问更加安全。可以避免a[-1]访问越界的问题访问方式,使得访问更加安全。而数组只能通过下标访问,在写程序中很容易出现越界的错误

(5.)vector和array提供了更好的遍历机制,即有正向迭代器和反向迭代器,数组支持指针作为迭代器进行遍历,但不提供反向迭代器。

(6.)vector和array提供了size()和Empty(),而数组只能通过sizeof()/strlen()以及遍历计数来获取大小和是否为空(使用strlen()获取数组大小只适用于字符数组。对于其他类型的数组,您需要手动计算数组长度

(7.)vector和array提供了两个容器对象的内容交换,即swap()的机制,而数组对于交换只能通过遍历的方式逐个交换元素

(8.)array提供了初始化所有成员的方法fill()

(9.)由于vector的动态内存变化的机制,在插入和删除时,需要考虑迭代的是否有效问题

(10.)vector和array在声明变量后,在声明周期完成后,会自动地释放其所占用的内存。对于数组如果用new[ ]/malloc申请的空间,必须用对应的delete[ ]和free来释放内存

性能比较

在许多情况下,数组、`std::array`和`std::vector`的性能差异可能并不明显,但在某些特定的使用场景下,它们的性能差异可能会变得非常显著。以下是一些关于这三者性能比较的观察:

  • **1. 内存分配:**

数组和`std::array`在编译时确定大小,因此它们的内存分配是静态的,这意味着它们在内存分配上的开销较小。相比之下,`std::vector`是动态分配内存的,当需要增加或减少元素时,可能需要重新分配内存,这可能导致更大的内存开销。

  • **2. 插入和删除元素:**

对于数组和`std::array`,插入和删除元素通常需要移动大量元素,这可能会导致较大的性能开销。相比之下,`std::vector`在尾部插入和删除元素的性能非常高效,但在中间或头部插入和删除元素可能需要移动大量元素,这可能导致较大的性能开销。

  • **3. 访问元素:**

数组、`std::array`和`std::vector`都支持通过下标访问元素,这是非常高效的。然而,`std::vector`和`std::array`还提供了额外的成员函数,如`at()`,这些函数在提供范围检查的同时可能会有一些额外的开销。

  • **4. 内存占用:**

由于`std::vector`需要存储额外的信息,如容量,因此它可能会占用比数组和`std::array`更多的内存。然而,这通常只在元素数量非常大时才会成为问题。

  • **5. 缓存友好性:**

由于数组、`std::array`和`std::vector`都使用连续的内存,因此它们都非常适合现代硬件的缓存系统,这可以显著提高性能。

总的来说,选择使用数组、`std::array`还是`std::vector`,应该根据具体的使用场景和需求来决定。在许多情况下,`std::vector`由于其灵活性和易用性,可能是一个更好的选择。然而,在对性能有严格要求的情况下,可能需要更仔细地考虑这三者的性能差异。

结语

**<font face="楷体" color=#984229 size =3>在我们的编程学习之旅中,理解是我们迈向更高层次的重要一步。然而,掌握新技能、新理念,始终需要时间和坚持。从心理学的角度看,学习往往伴随着不断的试错和调整,这就像是我们的大脑在逐渐优化其解决问题的“算法”。</font>**

**<font face="楷体" color=#15427 size =3>这就是为什么当我们遇到错误,我们应该将其视为学习和进步的机会,而不仅仅是困扰。通过理解和解决这些问题,我们不仅可以修复当前的代码,更可以提升我们的编程能力,防止在未来的项目中犯相同的错误。</font>**

**<font face="楷体" color=#9999 size =3>我鼓励大家积极参与进来,不断提升自己的编程技术。无论你是初学者还是有经验的开发者,我希望我的博客能对你的学习之路有所帮助。如果你觉得这篇文章有用,不妨点击收藏,或者留下你的评论分享你的见解和经验,也欢迎你对我博客的内容提出建议和问题。每一次的点赞、评论、分享和关注都是对我的最大支持,也是对我持续分享和创作的动力。

目录
相关文章
|
19天前
|
Python
使用array()函数创建数组
使用array()函数创建数组。
18 3
|
22天前
|
设计模式 存储 Android开发
c++的学习之路:18、容器适配器与反向迭代器
c++的学习之路:18、容器适配器与反向迭代器
21 0
|
5天前
|
调度 C++ 容器
【C++】手搓 list 容器
本文我们实现了STL库中重要的list 的模拟实现,其中最重要莫过于迭代器的封装类的书写,这是前所未有的操作(对于我来说,我是第一次使用这种结构)。通过list 的模拟实现也帮我们巩固了类与对象的知识,也强化了指针操作的思路。欢迎大家讨论分析。
12 1
|
8天前
|
存储 设计模式 算法
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
13 1
|
14天前
|
存储 算法 C++
详解C++中的STL(标准模板库)容器
【4月更文挑战第30天】C++ STL容器包括序列容器(如`vector`、`list`、`deque`、`forward_list`、`array`和`string`)、关联容器(如`set`、`multiset`、`map`和`multimap`)和容器适配器(如`stack`、`queue`和`priority_queue`)。它们为动态数组、链表、栈、队列、集合和映射等数据结构提供了高效实现。选择合适的容器类型可优化性能,满足不同编程需求。
|
16天前
|
存储 C++
【C++模板】模板实现通用的数组
【C++模板】模板实现通用的数组
|
20天前
|
存储 算法 程序员
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
|
21天前
|
存储 人工智能 C++
【重学C++】【指针】详解让人迷茫的指针数组和数组指针
【重学C++】【指针】详解让人迷茫的指针数组和数组指针
34 1
|
21天前
|
存储 索引 Python
多数pythoneer只知有列表list却不知道python也有array数组
多数pythoneer只知有列表list却不知道python也有array数组
26 0
|
28天前
|
C++ 容器
约瑟夫经典问题C++,STL容器queue解法
约瑟夫经典问题C++,STL容器queue解法
14 0