C++的动态数组

1、动态数组是内存连续的数组,在分配时不用指定所需的大小

2、当存储的数据超过动态数组的大小时,它会在内存中创建一个比第一个数组还大的新数组,把所有的东西都复制到这里,然后删除旧的那个。这样我们就有了一个新数组,有更多的存储空间,我们可以像这样不断地向它添加东西。

3、实际中,动态数组倾向于经常分配,因此并不能得到最佳性能。

4、当我们固定分配数组大小时,有时可能不够灵活。

因此想要动态数组更加灵活。

复制代码
#include<iostream>
#include<string>
#include<vector>

struct Vertex
{
    float x,y,z;
};

std::ostream& operator<<(std::ostream& stream,const Vertex& vertex) //输出运算法重载
{
    stream << vertex.x <<", "<< vertex.y <<", "<< vertex.z;
    return stream;
}

int main()
{
   // Vertex* vertices = new Vertex[5];//还是基于堆的固定大小的分配
    std::vector<Vertex> vertices;//尖括号中是vertices数组中元素的类型
    vertices.push_back({1,2,3});
    vertices.push_back({4,5,6});//向数组中添加元素
    for(int i=0;i<vertices.size();i++) //遍历数组
    {
        std::cout<< vertices[i] << std::endl;
    }
    
    vertices.erase(vertices.begin()+1);  
    //删除数组中特定的元素,erase()函数接收的参数是迭代器,因此我们不可以写vertices[1],我们要写vertices.begin()
    
    for(Vertex& v:vertices)
    {
        std::cout<<v<<std::endl;
    }
    std::cin.get();
}

vector如何优化?如何避免复制?

请看下一篇博客~~~

相关推荐
吕司9 小时前
LeetCode Hot Code —— 和为K的子数组
数据结构·算法·leetcode
東雪木9 小时前
Java学习——重载 (Overload) 与重写 (Override) 的核心区别、底层实现规则
java·开发语言·jvm·学习·java面试
爱丽_9 小时前
JVM GC 调优:内存指标、泄漏排查与线上自救
java·开发语言·jvm
AI自动化工坊9 小时前
OpenFang实战指南:用Rust构建高并发AI Agent操作系统
开发语言·人工智能·ai·rust·agent·ai agent
liu****9 小时前
LangChain-AI应用开发框架(一)
c++·python·langchain·本地部署大模型
承渊政道9 小时前
【优选算法】(实战剖析链表核心操作技巧)
开发语言·数据结构·c++·vscode·学习·算法·链表
wjs20249 小时前
Shell 变量
开发语言
代码改善世界9 小时前
【C++初阶】string类(二):常用接口全解析
开发语言·c++
前端郭德纲9 小时前
JavaScript原生开发与鸿蒙原生开发对比
开发语言·javascript·harmonyos
stolentime9 小时前
树套树+标记永久化:[POI 2006] TET-Tetris 3D&&SPOJ1741 TETRIS3D - Tetris 3D题解
c++·算法·线段树·树套树·标记永久化