【发布时间】:2010-09-12 15:22:33
【问题描述】:
Boost 旨在成为每个 C++ 用户都可以使用的标准非标准 C++ 库。假设它可用于开源 C++ 项目是否合理,或者它是一个太大的依赖关系?
【问题讨论】:
标签: c++ boost standard-library
Boost 旨在成为每个 C++ 用户都可以使用的标准非标准 C++ 库。假设它可用于开源 C++ 项目是否合理,或者它是一个太大的依赖关系?
【问题讨论】:
标签: c++ boost standard-library
基本上,您的问题归结为“将 [free library xyz] 作为 C++ 开源项目的依赖项是否合理。”
现在考虑一下 Stroustrup 的以下引用,答案真的很简单:
没有好的库,大部分有趣的任务都很难完成 C++;但是如果有一个好的库,几乎任何任务都可以轻松完成
假设这是正确的(根据我的经验,它是正确的)那么编写一个大小合理的 C++ 项目没有依赖是完全不合理的。
进一步发展这个论点,在(开发人员的)客户端系统上可以合理预期的一个 C++ 依赖项(除了系统库)是 Boost 库。 我知道他们不是,但对于软件来说,这并不是一个不合理的假设。
如果一个软件甚至不能依赖 Boost,它就不能依赖 任何 库。
【讨论】:
看看http://www.boost.org/doc/tools.html。具体来说,如果您想将 boost 依赖项嵌入到您的项目中,bcp 实用程序会派上用场。网站摘录:
“bcp 实用程序是一种用于提取 Boost 子集的工具,它对于希望将其库与 Boost 分开分发的 Boost 作者以及希望将 Boost 子集与他们的应用程序一起分发的 Boost 用户非常有用。bcp 还可以报告您的代码依赖于 Boost 的哪些部分,以及这些依赖项使用了哪些许可证。”
当然,这可能有一些缺点 - 但至少您应该意识到这样做的可能性。
【讨论】:
我以前对向系统引入依赖关系非常谨慎,但现在我发现依赖关系并不是什么大问题。现代操作系统带有包管理器,这些包管理器通常可以自动解决依赖关系,或者至少可以让管理员轻松安装所需的内容。例如,Boost 在 Gentoo-Postage 下作为 dev-libs/boost 可用,在 FreeBSD 端口下作为 devel/boost 可用。
现代开源软件在其他系统上构建了大量内容。在recent study 中,通过跟踪 FreeBSD 包的依赖关系,我们确定在我们的 FreeBSD 4.11 系统中的 12,357 个端口包,总共有 21,135 个库依赖项;即,除了作为基本系统一部分的 52 个库之外,它们需要一个库才能编译。库依赖包含 688 个不同的库,而单个项目使用的不同外部库的数量在 1 到 38 之间变化,众数值为 2。此外,5,117 个项目使用了至少一个外部库,405 个项目使用了 10 个或更多.
最终,您的问题的答案将来自成本与收益分析。重用成熟、广泛使用、经过审查和测试的库(如 Boost)的好处是否大于依赖项的低成本和不断下降的成本?对于 Boost 工具的任何重要用途,答案是您应该继续使用 Boost。
【讨论】:
这取决于。如果您在 Boost 中使用仅定义类模板的头文件 - 那么可以继续使用它,因为它不会吸收任何 Boost 共享库,因为所有代码都是在编译时生成的,没有外部依赖项。版本控制问题对于任何共享的 c++ 库来说都是一个难题,而 Boost 也无法幸免,因此,如果您可以完全避免该问题,那将是一件好事。
【讨论】:
在编写 C++ 代码时使用 boost 的好处远远超过了分发开源代码的额外复杂性。
我在 Programmer's Notepad 上工作,代码依赖于 boost 以进行测试、智能指针和 python 集成。由于要求,已经有一些投诉,但如果他们想处理代码,大多数人都会继续这样做。接受 boost 依赖是我从未后悔的决定。
为了稍微降低其他人的复杂性,我为 boost python 包含了版本化的预构建库,以便他们需要做的就是在其包含目录中提供 boost。
【讨论】:
KDE 也依赖于 Boost。
但是,这主要取决于您的目标,甚至更多取决于您的目标受众,而不是您的项目范围。例如 TinyJSON(非常小的项目),几乎是 100% Boost,但这很好,因为它提供的 API 类似于 Boost,并且针对需要 JSON 绑定的 Boost 程序员。然而,许多其他 JSON 库不使用 Boost,因为它们针对的是其他受众。
另一方面,我不能在工作中使用 Boost,而且我知道许多其他开发人员(在他们的日常工作中)都在同一条船上。所以我想你可以说如果你的目标是开源的,并且一个使用 Boost 的组,请继续。如果您的目标是企业,您可能需要考虑一下,并从 Boost 中复制粘贴必要的部分(并承诺他们的支持),以使您的项目能够正常工作。
【讨论】:
我认为 Boost 提供的广泛功能,正如你所说,它是标准的非标准 C++ 库,证明它是一个依赖项。
【讨论】:
不幸的是,对于 ubuntu,它们很容易获得,但对于 RHEL 4&5,我几乎总是最终使用 tarball 制作它们。它们是很棒的库,只是非常大......就像有时你真正需要的只是一个图钉时使用一个铁轨钉。
【讨论】:
这完全取决于您使用 Boost 的方式。正如 Diomidis 所说,如果您要使用 Boost 的一些重要设施,那就继续吧。使用图书馆不是犯罪。
当然,有很多人不喜欢使用 Boost,因为引入新的依赖项总是有一些缺点和额外的担忧,但是在一个开源项目中......在我看来,如果你只是使用它们甚至可以想要学习它们或提高你的技能。
【讨论】: