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

性能设计模式

class Singleton {
public:
static Singleton& getInstance() {static Singleton instance; // 局部静态变量return instance;
}
private:Singleton() {}Singleton(const Singleton&) = delete; // 禁止拷贝Singleton& operator=(const Singleton&) = delete; // 禁止赋值
};

容器类型

插入性能

删除性能

查找性能

随机访问性能

内存使用情况

底层实现

std::vector

末尾 O(1),其他 O(n)

末尾 O(1),其他 O(n)

O(n)

O(1)

紧凑(数组式存储)

动态数组

std::deque

前后 O(1)

前后 O(1)

O(n)

O(1)

较紧凑

分块数组

std::list

O(1)

O(1)

O(n)

O(n)

高(每个元素有指针)

双向链表

std::forward_list

O(1)

O(1)

O(n)

O(n)

较低

单向链表

std::map

O(log n)

O(log n)

O(log n)

O(log n)

较高(树结构)

红黑树

std::unordered_map

O(1) 均摊,最坏 O(n)

O(1) 均摊,最坏 O(n)

O(1) 均摊,最坏 O(n)

不支持

较高(哈希表开销)

哈希表

std::set

O(log n)

O(log n)

O(log n)

O(log n)

较高(树结构)

红黑树

std::unordered_set

O(1) 均摊,最坏 O(n)

O(1) 均摊,最坏 O(n)

O(1) 均摊,最坏 O(n)

不支持

较高(哈希表开销)

哈希表

std::stack

O(1)

O(1)

不支持

不支持

与底层容器相同

deque / vector

std::queue

O(1)

O(1)

不支持

不支持

与底层容器相同

deque

std::priority_queue

O(log n)

O(log n)

O(1)

不支持

与底层容器相同

堆结构

  • mapmap 中的元素是按 键值的升序 存储的。由于底层使用了红黑树结构,每次插入元素时会自动对元素进行排序。你可以在遍历时按键值的顺序访问元素。

  • unordered_mapunordered_map 中的元素 没有特定的顺序。哈希表不维护元素的顺序,元素的插入顺序和访问顺序没有特定规则,完全取决于哈希值的分布。

http://www.lryc.cn/news/447782.html

相关文章:

  • Android 热点分享二维码功能简单介绍
  • SIEM之王,能否克服创新者的窘境?
  • (JAVA)浅尝关于 “栈” 数据结构
  • 【前端】ES13:ES13新特性
  • vuepress 浏览器加载缓存,总是显示旧页面,无法自动刷新数据的解决方法
  • 如何使用代理IP解决反爬虫问题
  • QT学习笔记之绘图
  • 大数据新视界 --大数据大厂之数据清洗工具 OpenRefine 实战:清理与转换数据
  • 基于QT的C++中小项目软件开发架构源码
  • self-supervised, weakly supervised, and supervised respectively区别
  • 安卓好软-----手机屏幕自动点击工具 无需root权限
  • 【Redis】主从复制(下)--主从复制原理和流程
  • Pencils Protocol上线 Vaults 产品,为 $DAPP 深入赋能
  • uni-app+vue3+pina实现全局加载中效果,自定义全局变量和函数可供所有页面使用
  • 基于SSM+小程序的在线课堂微信管理系统(在线课堂1)(源码+sql脚本+视频导入教程+文档)
  • Uniapp 微信小程序 最新 获取用户头像 和 昵称 方法 有效可用
  • 儿童手抄报模板-200个(家有神兽必备)
  • 动态规划入门题目->使用最小费用爬楼梯
  • 中间添加一条可以拖拽的分界线,来动态调整两个模块的宽度
  • C++的vector优化
  • 基于飞腾平台的OpenCV的编译与安装
  • pyside6与协程
  • 手机如何五开玩梦幻西游端游?用GameViewer远程手机免费畅玩梦幻西游
  • 【笔记】X射线物理基础
  • Vue3与Flask后端Demo
  • 第一本RAG书籍《大模型RAG实战》出版!
  • Pandas -----------------------基础知识(四)
  • 鼎阳加油-IOC关键技术问题的解决记
  • 【HarmonyOS】TaskPool非阻塞UI
  • 关于使用/bin/sh -c 用于Dockerfile的Entrypoint的问题