草庐IT

ZN5boost

全部标签

C++ 依赖注入(inject)——通过引用还是通过 boost::shared_ptr?

在需要构造函数依赖注入(inject)的情况下,使用引用注入(inject)与使用boost::shared_ptr注入(inject)有哪些注意事项?还有其他常见的方法吗?它与上述两种方法相比如何? 最佳答案 您可以选择如何管理要注入(inject)的对象的生命周期。整体架构可能会决定哪种选择最有意义。有了引用,更高层次的东西必须管理对象的生命周期;使用shared_ptr将自动管理生命周期。 关于C++依赖注入(inject)——通过引用还是通过boost::shared_ptr?,

c++ - 如何在 Linux 中正确链接 boost 库

我一直在尝试完成Boost教程,但我在链接文件系统库时遇到了困难。我有Ubuntu12.10。安装并不难sudoapt-getinstalllibboost-all-dev这将所有头文件放在/usr/local/include中,编译后的源代码放在/usr/lib/[--标题][--二进制文件]我写了这个程序[--program]。当我尝试编译它时g++-gtut1.cpp-otut1-lboost_system-lboost_filesystem得到这个错误:[--errors]。在http://www.boost.org/doc/libs/1_53_0/more/getting_s

c++ - boost::exception - 如何打印细节?

我的程序中有这样的代码:catch(boost::exception&ex){//errorhandling}如何打印详细信息?错误消息、堆栈跟踪等? 最佳答案 对于像boost::exception这样通用的东西,我认为您正在寻找boost::diagnostic_information函数来获得一个漂亮的字符串表示。#includecatch(constboost::exception&ex){//errorhandlingstd::stringinfo=boost::diagnostic_information(ex);log

c++ - 使用/std :c++latest (or C++17/N4190) 使用 MSVC2015 编译 boost

当我尝试使用带有/std:c++latest标志的MSVC2015构建boost时,出现错误:boost\algorithm\string\detail\case_conv.hpp(33):errorC2143:syntaxerror:missing','before'指向://atolowerfunctortemplatestructto_lowerF:publicstd::unary_function现在这似乎是由于此处提到的N4190:https://www.visualstudio.com/en-us/news/releasenotes/vs2015-update3-vs/st

c++ - 如何使用 C++ Boost 的 regex_iterator()

我正在使用Boost来匹配字符串中的子字符串。Io遍历结果,我需要使用regex_iterator().那是我找到的唯一用法示例,但我不理解回调。有人可以给我一个函数的用法示例吗?让我们假设我的输入文本是:"HelloeverybodythisisasentenseBlabla14..yesdate04/15/1986"我想得到:"Hello""everybody""this""is""a""sentense""bla""yes""date" 最佳答案 如果您不理解示例的唯一部分是回调,请考虑:std::for_each(m1,m2

c++ - boost::smart_ptr 可以用于多态吗?

可以boost::smart_ptr比如scoped_ptr和shared_ptr可以用在多态中吗?classSomeClass{public:SomeClass(){a_ptr.reset(newSubClass);}private:boost::scoped_ptra_ptr;} 最佳答案 我相信答案是肯定的;对boost指针进行编码,以便在父类(superclass)所在的任何地方都接受派生类。 关于c++-boost::smart_ptr可以用于多态吗?,我们在StackOver

c++ - Boost精神太贪心

我介于对boost::spirit的深深钦佩和不理解它的永恒挫折之间;)我的字符串过于贪婪,因此不匹配。下面是一个不解析的最小示例,因为txt规则吃完了。有关我想做的事情的更多信息:目标是解析一些伪SQL,我跳过空格。在类似的声明中selectfoo.id,bar.idfromfoo,baz我需要将from视为特殊关键字。规则类似于"select">>txt%','>>"from">>txt%','但它显然不起作用,因为它将foo的bar.id视为一个项目。#include#includenamespaceqi=boost::spirit::qi;intmain(int,char**)

c++ - 无法在 boost 1.57 中编译 boost/any_iterator.hpp

在(尝试)升级VS2012项目以使用boost1.57之后,我无法再编译——boost/any_iterator.hpp中出现大量错误消息(见下文)。作为测试,我创建了一个新项目,其中只包含一个空的主函数和#include"boost/any_iterator.hpp"并得到了相同的错误集。这是它提示的代码://snippetfromboost/any_iterator.hpptemplateclasspostfix_increment_proxy>{//...};同一文件中还有另一个类遵循相同的模式并生成相同的错误。range_detail::any_iterator在文件中稍高一点

c++ - boost::optional 对 bool 的隐式转换消失了吗?

我开始将vc++10/boost1.48代码库移植到vc++12/boost1.57,但我收到一个错误,提示boost::optional无法转换为bool。我以为这是boost::optional的一个特性,它被删除了吗?例子:boolfizz(){boost::optionalbuzz;returnbuzz;}给予Error21errorC2440:'return':cannotconvertfrom'boost::optional'to'bool' 最佳答案 是的。Boost1.55仍然使用SafeBoolIdiom://im

c++ - boost optional 和 std::experimental optional assignment 之间的区别

通常当函数返回boost::optional时我见过很多人返回空括号{}指定一个空值,它工作正常并且比返回boost::none短.我尝试做一些类似于清空boost::optional的事情,但是当调用复制赋值运算符(或者很可能是移动赋值运算符)并在右侧使用空大括号时,空大括号被转换为int然后将该值分配给可选值,所以我最终得到变量设置为0而不是我预期的空值。这是一个例子https://godbolt.org/g/HiF92v,如果我用std::experimental::optional做同样的尝试我得到了我期望的结果(只需在示例中替换为std::experimental::opti