草庐IT

BOOST_STRINGIZE

全部标签

c++ - 如何在 Travis CI 中使用最新的 Boost 版本

我刚开始使用Travis-CI它工作得很好,但我的一些项目需要最新版本的Boost。特别是,一个需要Boost1.59或更新版本,而Travis-CI只有Boost1.55可用。有没有一种简单的方法可以在构建容器中安装Boost>=1.59?我可以看到有些人在编译他们自己的程序之前先下载并编译Boost,但在我看来这似乎是一种资源浪费——肯定有某个地方可以使用可用的包吗? 最佳答案 当然:回想一下Travis使用Ubuntu请记住Canonical提供Lunchpad来构建个人包存档(PPA)因此,将您需要的内容(可能是从Debia

c++ - boost 日志记录,按命名范围过滤

我在我的应用程序中使用了boostlog,虽然配置起来很棘手,但它通常运行良好。但是现在,我想在我的应用程序中添加一些更高级的过滤逻辑,但我想不通。我想要的是有两个“级别”的过滤:我已经在使用不同级别的“严重性记录器”,例如debug,warn,note等等。这是设置和工作。我想添加一种额外的方法来过滤记录,方法是查看记录源自的“命名范围”。例如,我希望只能看到严重性>=note的记录,AND在NAMED_SCOPE内的monthly.我已经成功地使用了BOOST_LOG_NAMED_SCOPE()宏,并且可以在日志消息中看到作用域堆栈。我尝试使用boost::phoenix实现自定义

c++ - Boost.asio 和异步链,unique_ptr?

我对异步编程不是很熟悉,我有一个问题。我的问题如下。给定boost.asio中C++11的echo_server示例:http://www.boost.org/doc/libs/1_60_0/doc/html/boost_asio/example/cpp11/spawn/echo_server.cpp我想知道std::make_shared可以在C++14中替换为std::unique_ptr在C++14中,避免了引用计数的开销。我不确定,因为我们有shared_from_this()但不是像unique_from_this()这样的东西,那么我怎样才能访问unique_ptr从里面t

c++ - 与 boost::property_tree XML 解析器一起使用时 boost::coroutine 库崩溃

我正在使用Simple-Web-Server用于创建将XML转换为JSON的简单Web服务的库,反之亦然。反过来,它使用了几个boost库以及其中的boost::coroutine。对于XMLJSON转换,我使用boost::property_tree库进行中间表示。这是代码:#include#include#include#defineBOOST_SPIRIT_THREADSAFE#include#include#includeusingnamespacestd;usingnamespaceboost::property_tree;usingHttpServer=SimpleWeb:

c++ - 'boost::exception_detail::clone_impl<boost::exception_detail::error_info_injector<boost::system::system_error>>

我创建了客户端应用程序。当我发送单个消息clientsever时它工作正常。但是当我出于性能目的发送大量消息时,客户端会以两种不同的方式崩溃:(gdb)runStartingprogram:/home/x64joxer/workerGenerators/Worker2/worker-t-i192.168.0.6-p6000-d5-l//home/x64joxer/workerGenerators/Worker2/[Threaddebuggingusinglibthread_dbenabled]Usinghostlibthread_dblibrary"/lib/x86_64-linux-

c++ - 使用 Boost 库 Qt C++ 更新翻译文件

我在我的C++项目中使用Boost库。我将它包含在PRO文件中,如下所示:win32:INCLUDEPATH+=C:/boost_1_60_0win32:LIBS+="-LC:/boost_1_60_0/stage/lib/"但是,当我在终端(cmd)上运行以下命令来更新我的翻译文件时:lupdateMyProject.pro它在Boost库路径中搜索文件进行更新。这正常吗?我该怎么做才能不在Boost库路径中搜索?现在,当我需要运行lupdate命令时,我正在评论Boost包含行,但我不想每次需要更新我的翻译文件时都这样做。Qt5.3.2boost1.6.0

c++ - 为什么 Boost 原子使用中的多生产者队列是无等待的

BoostAtomic示例中的无等待多生产者队列:templateclasswaitfree_queue{public:structnode{Tdata;node*next;};voidpush(constT&data){node*n=newnode;n->data=data;node*stale_head=head_.load(boost::memory_order_relaxed);do{n->next=stale_head;}while(!head_.compare_exchange_weak(stale_head,n,boost::memory_order_release));

c++ - 如何使用 Boost.Spirit.Qi 增量解析(并作用于)大文件?

我为自定义文本文件格式创建了一个Qi解析器。有数以万计的条目要处理,每个条目通常有1-10个子条目。我放了一个精简的解析器工作示例here.#include#include#include#include#include#include#include#include#include#include#include#include#includeusingstd::string;usingstd::vector;usingstd::cout;usingstd::endl;namespacemodel{namespaceqi=boost::spirit::qi;structspectru

c++ - boost 收集范围的适配器

我想编写一个boost适配器放在适配器链的末尾以创建一个集合,如下所示:sets=input|filtered(...)|transformed(...)|to_set;使用Method3.1我写了下面的代码,它似乎按预期工作:namespacedetail{structto_set_forwarder{};};templateinlineautooperator|(R&r,detail::to_set_forwarder){returnset(r.begin(),r.end());}templateinlineautooperator|(constR&r,detail::to_set

c++ - 使用 boost spirit 的递归 BNF 规则

我正在尝试使用boostspirit为以下BNF规则编写解析器(Boostv1.64)规则是:::=integer::="in"|"out"|"in_out"::="["[]"]"::="("(",")+")"::=||下面是我的尝试,使用boost::make_recursive_variant它似乎在字符串in上工作正常但它在in[2]上失败了。我的错误在哪里?什么是优雅的解决方案?namespaceAst{enumclassTypeName{IN,OUT,INOUT};usingNumericLiteral=int;usingTypeSpec=boost::make_recurs