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

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()> 和捕获列表。

http://www.xdnf.cn/news/13294.html

相关文章:

  • MySQL基础语法总结
  • 如何在 Python 中去除列表重复项并保留顺序
  • BeckHoff <--> 基恩士(CV-X300)三维机械手视觉系统的通讯 控制
  • minio私有桶授权访问
  • Leetcode 3574. Maximize Subarray GCD Score
  • java 面向对象编程
  • Linux下制作Nginx绿色免安装包
  • 7.4.分块查找
  • vue3 字体颜色设置的多种方式
  • sysctl优先级顺序
  • 第3章 MySQL数据类型
  • (八)深度循环神经网络:长序列建模、注意力机制与多模态融合
  • CloudReadering
  • Prompt Tuning、P-Tuning、Prefix Tuning的区别
  • c语言中的hashmap
  • ArkUI-X跨平台Bridge最佳实践
  • 张彬彬《龙骨焚箱》开机 奇幻冒险题材引期待
  • 在微服务架构中,怎么搭建Maven私服
  • crackme007
  • mysql8.4备份与恢复实践
  • bilibili-mcp 使用示例
  • 7.6 Finetuning the LLM on instruction data
  • 论文分享 _ Ladder:一种基于收敛的结构化图区块链_2025-06-10
  • 实战案例-FPGA如何实现JESD204B可重复的延迟
  • 2005-2021年中国地下水位年鉴数据(EXCEL/PDF)包含:各省监测点、监测深度等
  • 【存储系统】
  • 理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
  • 全新AI驱动Workspace Security 套件发布!Fortinet 电子邮件安全产品矩阵升级
  • PHP 多种内置的验证规则和函数
  • 在Jenkins上配置邮箱通知