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

STL 5 适配器

STL 适配器是一类特殊的组件,用于修改其他组件的接口,使其适配特定场景。它们本身不提供完整功能,而是通过包装现有组件来改变其行为。

文章目录

    • 1.适配器
      • 1.三种主要容器适配器
        • 1.原理
        • 2.std::stack
        • 3.std::queue
        • 4.std::priority_queue
      • 2.常见迭代器适配器
      • 3.函数适配器
        • 1.std::bind
        • 2.std::function

1.适配器

适配器是一种结构型设计模式,通过改变现有组件的接口,使其符合客户端的需求。在 STL 中,适配器主要分为三类:
1.容器适配器(Container Adapters)
2.迭代器适配器(Iterator Adapters)
3.函数适配器(Function Adapters)

1.三种主要容器适配器

1.原理

适配器内部持有一个被适配对象的实例,并通过转发调用其方法来实现新接口

2.std::stack

LIFO(后进先出)栈结构

std::stack默认使用std::deque作为底层容器,也可指定其他容器(需支持back()、push_back()、pop_back())

3.std::queue

FIFO(先进先出)队列结构

std::queue默认使用std::deque作为底层容器,也可指定其他容器(需支持front()、back()、push_back()、pop_front())

4.std::priority_queue

优先级队列(最大堆)

通常使用堆(如二叉堆)实现,保证插入和删除操作的时间复杂度为 O (log n)。

2.常见迭代器适配器

1.std::reverse_iterator 反向遍历容器
std::rbegin(v), std::rend(v)

2.std::back_insert_iterator 在容器尾部插入元素 std::back_inserter(v)

3.std::front_insert_iterator 在容器头部插入元素 std::front_inserter(l)

4.std::insert_iterator 在指定位置插入元素 std::inserter(v, pos)

5.std::move_iterator 将普通迭代器转换为移动迭代器 std::make_move_iterator(it)

3.函数适配器

1.std::bind

通用参数绑定和重排 bind(func, _1, 2)

template< class F, class… Args >/unspecified/ bind( F&& f, Args&&… args );

1.f:要绑定的可调用对象(函数、成员函数、函数对象等)。

2.args:要绑定的参数列表,可包含占位符(如 std::placeholders::_1)。

3.占位符(Placeholders)
std::placeholders::_1, _2, _3, … 表示新函数的第 1、2、3… 个参数:

2.std::function

std::function 是 C++11 引入的一种通用多态函数包装器,它可以存储、复制和调用任何可调用对象(函数、Lambda、函数指针、成员函数等)。

1.核心功能
1.类型擦除:将不同类型的可调用对象包装为统一接口。
2.多态存储:可以存储函数、Lambda、函数对象等。
3.延迟调用:存储可调用对象,在需要时执行。
std::function<int(int, int)> add

2.性能开销
1.类型擦除:运行时需动态查找调用目标,比直接调用慢约 20%。
2.堆分配:当存储的对象较大时,可能触发堆分配。

3.优化建议
1.优先使用 Lambda:直接传递 Lambda 而非 std::function,避免类型擦除。
2.小对象优先值传递:通过 std::function 存储小对象(如简单 Lambda)。
3.大对象使用引用:存储大对象时使用 std::function<void()> 和捕获列表。

相关文章:

  • leetcode_35.搜索插入位置
  • Vue 模板语法之指令语法详解
  • 如何xml序列化 和反序列化类中包含的类
  • 如何删除导出的xml中的xmlns:xsd=
  • 【无标题新手学习期权从买入看涨期权开始】
  • 分析VSS,VCC和VDD
  • 电路笔记(元器件):并串转换芯片 SN65LV1023A 10:1 LVDS 串行器/解串器变送器 100 至 660Mbps
  • Dispatch PDI(DPDI)kettle调度管理平台稳定版本,正式登场!
  • 突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合
  • 【解密LSTM、GRU如何解决传统RNN梯度消失问题】
  • 阳台储能新纪元:ADL200N-CT/D16-WF-1导轨表,家庭能源自由的钥匙
  • 2023年全国研究生数学建模竞赛华为杯D题区域双碳目标与路径规划研究求解全过程文档及程序
  • LangChain Chat History概念指南
  • 案例解读:交安与建安安全员 C 证在实践中的差异
  • 小说系统开发:打造属于你的数字阅读王国
  • [小白]java之复杂JSON解析【超详细】
  • Vue3实现键盘字母筛选功能
  • Day.27
  • 第四章 W55MH32初体验
  • MySQL中的隐式主键和隐藏列
  • 如何做影视网站/网站的seo优化报告
  • 深圳住房和建设局网站 宝安/公司推广渠道
  • 外贸网站建设流程/如何建立自己的网站?
  • 网站底部版权html代码/新产品的推广销售方法
  • wordpress推荐管理/seo快速上排名
  • 电商类网站/网络营销公司哪家可靠