”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么在 C++11 中使用非成员 `begin` 和 `end` 函数?

为什么在 C++11 中使用非成员 `begin` 和 `end` 函数?

发布于2024-11-10
浏览:665

Why Use Non-Member `begin` and `end` Functions in C  11?

为什么在 C 11 中使用非成员 begin 和 end 函数?

C 11 中的标准容器提供成员函数 begin 和 end 以及自由函数,相同的名字。然而,人们对这些自由函数的优点和用例产生了疑问,特别是考虑到它们在标准容器中的明显冗余。

虽然 C 11 中引入的自由函数可能看起来只是简单地调用其相应的容器成员函数,它们提供了显着的好处,特别是对于非标准容器和涉及容器异构集合的场景。

此外,自由函数在处理不同容器类型的迭代器时提供了更大的灵活性和类型安全性。例如,它们允许在容器本身没有自己的 begin 或 end 成员函数(例如 C 数组)的情况下使用 begin 和 end 。

通过使用自由的 begin 和 end 函数,您可以可以实现更通用的编程,适用于更广泛的数据结构,包括那些不可修改或缺乏自己定制的迭代器实现的数据结构。这增强了代码的可重用性并简化了异构容器集合的操作。

最新教程 更多>
  • 如何在 Visual Studio 2012 中连接 MySQL 数据库?
    如何在 Visual Studio 2012 中连接 MySQL 数据库?
    在 Visual Studio 2012 中连接 MySQL 数据源在 Visual Studio 2012 中 MySQL 数据源与实体框架 (EF) 的集成一直是一个主题的讨论。然而,向 DataSource Dialog 添加 MySQL 数据库给开发人员带来了挑战。事实证明,MySQL Co...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • Java中线程引用设置为Null时会产生垃圾吗?
    Java中线程引用设置为Null时会产生垃圾吗?
    Java 线程:垃圾收集与否?在此 Java 代码片段中,创建了一个新线程,并使用 t.start( )。但是,启动线程后,线程引用 t 被设置为 null,且 t = null。这就提出了一个问题:在没有主动引用线程的情况下,线程是否会被垃圾收集。Java 中的垃圾收集当垃圾收集器在 Java 中...
    编程 发布于2024-11-18
  • 为什么我的 Python MySQL 插入不起作用?
    为什么我的 Python MySQL 插入不起作用?
    Python MySQL 插入操作疑难解答在 Python 中,使用 MySQL API 与 MySQL 数据库交互,插入记录可能会遇到障碍。本文解决了这样一个问题:尽管实现看似正确,但记录却无法插入。提供的代码建立了与数据库的连接,并尝试将记录插入“文档”表中。但是,插入操作失败。要解决这个问题,...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • 为什么 C++ 构造函数有两个符号?
    为什么 C++ 构造函数有两个符号?
    C 构造函数的双重符号Itanium C ABI 指定构造函数的重整名称包含有关其类型和参数的信息。因此,在库中观察到的两个构造函数条目源于它们不同的构造函数类型:完整对象构造函数(C1):此构造函数完全初始化对象,包括任何虚拟基类.基础对象构造函数 (C2): 此构造函数初始化对象本身以及数据成员...
    编程 发布于2024-11-18
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-18
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-18
  • WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 和内存屏障在访问共享变量的多线程环境中,强制同步至关重要以防止出现意外结果。 Go 中的一种此类机制是“sync.WaitGroup”包,它有助于管理并发运行的 goroutine。当前的问题围绕“WaitGroup.Wait()”和内存屏障之间的关系展开具体代码片...
    编程 发布于2024-11-18
  • 在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    将浮点数精确转换为具有指定十进制精度的字符串在 C 中,将浮点数转换为具有特定精度的字符串,并且小数位需要仔细考虑。本指南探讨了两种常见的解决方案:stringstream 和 C 17 中的 to_chars 函数。使用 StringstreamStringstream 是用于在 C 中操作字符串...
    编程 发布于2024-11-18
  • \“需要帮助修改默认日历选择器的 UI\”
    \“需要帮助修改默认日历选择器的 UI\”
    嗨,团队,我在 AG 网格单元中使用日历,但我无法修改此日历的 UI,也无法检查它。我想更改日历的 UI。 请参阅链接以获取更多说明 https://www.ag-grid.com/examples/provided-cell-editors-date/date-editor/modules/typ...
    编程 发布于2024-11-18
  • 为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    MySQL 文件写入错误(Errcode 28):诊断和解决遇到错误“Errorwriting file '/tmp/MY1fnqpm' (Errcode: 28)” 在 MySQL 查询中,根本原因通常在于可用磁盘空间不足。要确认这一点,请使用 perror 命令:$ perror...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    使用 Sequelize CLI 从 Sequelize 模型自动生成迁移人们可能拥有预先存在的 Sequelize 模型,但希望使用迁移而不是数据库同步。 Sequelize CLI 提供了一篇文章中概述的解决方案,其中指出,“当利用 CLI 进行模型生成时,您将自动获取必要的迁移脚本。”要实现此...
    编程 发布于2024-11-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3