草庐IT

boost_macro_reference

全部标签

c++ - 使用 Boost.Log 构建 Boost "error: target { simple_event_log.mc. } has no type"

我正在尝试构建Boost.Log(http://boost-log.sourceforge.net/libs/log/doc/html/index.html)。我将它添加到我的boost源并执行了我常用的boost构建命令。b2--build-dir="D:\boost\1.51.0\boost"toolset=gccvariant=releaselink=staticthreading=multiruntime-link=static--build-type=complete但什么也没发生,最后我收到了这个:D:/boost/1.51.0/src/tools/build/v2/bui

c++ - std::fstream 和 Boost Iostreams 库之间的区别

我是BOOST库的新手。今天看到一小段代码,其中读写PGM格式图片是用BoostIostreamsLibrary实现的。随着我对STL越来越熟悉,我可以很容易地看出std::fstream可以完成同样的工作。那么我的问题是,在这样一个简单的读写PGM图像的应用程序中使用Boost库有什么意义呢?此外,我想知道在什么情况下最需要BOOSTIostreams库。谢谢! 最佳答案 来自std::fstreamreference:fstreamprovidesaninterfacetoreadandwritedatafromfilesasi

c++ - "-D__STDC_FORMAT_MACROS"gnu 编译器选项

我正在清理我的Makefile并试图了解那里实际发生了什么。我遇到了上述选项。它必须启用一些宏来保证与旧C库的兼容性,但我找不到它的用途。gnu编译器(g++)选项是什么g++-D__STDC_FORMAT_MACROS意思还是做?g++甚至有必要吗?PS:我在Linux下工作 最佳答案 感谢Nick的链接,我得出结论,g++不需要它。它与C的inttype.h和printf有关。来自链接Inparticular,thesymbol__STDC_FORMAT_MACROS,mentionedinfootnote182oftheCst

c++ - 添加多个相同类型的 boost::error_infos 到一个 boost::exception

#include#includestructmyexception:virtualboost::exception,virtualstd::exception{};typedefboost::error_infoinfo;voidmain(){try{BOOST_THROW_EXCEPTION(myexception()这将输出[structtag_info*]=2我明白为什么会这样,但宁愿让它输出[structtag_info*]=1[structtag_info*]=2我当然可以typedefinfo作为boost::error_info>然后将所有信息累积在std::vector

c++ - boost::asio 接受器避免内存泄漏

使用boost::asio我使用async_accept接受连接。这很好用,但有一个问题,我需要一个如何处理它的建议。使用典型的async_accept:Listener::Listener(intport):acceptor(io,ip::tcp::endpoint(ip::tcp::v4(),port)),socket(io){start_accept();}voidListener::start_accept(){Request*r=newRequest(io);acceptor.async_accept(r->socket(),boost::bind(&Listener::ha

c++ - boost::asio::streambuf 缩小到适合?

boost::asio::streambuf的大小会一直增加,直到consume()被调用。即使在调用consume()之后,底层缓冲区使用的内存也永远不会被释放。例如:下面的代码首先创建了一个没有指定max_size的streambuf。然后它将14Mb数据转储到streambuf中。然后它消耗所有这些14MB数据。在2000点,streambuf.size()为0,但“top”显示进程仍占用14MB内存。我不想指定max_size。streambuf为空后,有什么方法可以收缩它吗?#include#include#includeintmain(){{boost::asio::str

c++ - boost::thread 和 std::thread 之间的区别

我有一个使用boost::thread的地方(例如使用boost::asio)std::vector>threads;for(std::size_ti=0;ithread(newboost::thread(boost::bind(&boost::asio::io_service::run,io_services_[i])));threads.push_back(thread);}如果我尝试将它与std:thread一起使用,我会得到编译错误:std::vectorthreads;for(std::size_ti=0;iioServices.size();++i){std::thread

c++ - BOOST MPL 添加两个 list_c 对象导致意外行为

我有以下代码:#include#include#include#include#include#include#include#include#includeusingnamespaceboost::mpl;typedeflist_cevens;typedeflist_cprimes;typedeflist_csums;typedeftransform>::typeresult;BOOST_MPL_ASSERT((equal>));intmain(){std::cout它编译,所以BOOST_MPL_ASSERT成立。但是,运行它时,main函数中的断言失败。这是什么意思?包含相同元素

c++ - boost::spirit ,如何获取占位符的 "value"

我正在尝试构建一个接受格式为“/integer/(/integer/)”的字符串并生成一个std::tuple的解析器现在我有:qi::rule()>parser=(qi::int_>>'('>>qi::int_>>')')[_val=std::make_tuple(qi::_1,qi::_2)]无法编译,因为占位符qi::_i的类型不正确。如何从占位符中“提取”基础值? 最佳答案 嗯,你可以只使用自动属性传播(又名“自动规则”):#include#include#includenamespaceqi=boost::spirit::

c++ - 类型转换 boost::fusion::vector

boost::fusion::vector的编号形式看起来像templateclassvector1;templateclassvector2;等等可变参数形式看起来像templateclassvector;那么有没有办法在编译时将boost::fusion::vector从编号形式转换为可变参数形式? 最佳答案 您真的需要编译时转换吗?两者之间存在运行时转换,所以我看不出有必要:vector2a(13,'b');vectorb=a;不过我试着玩玩。我对我的回答不满意,但也许您可以继续努力以找到更好的答案。我希望能够使用一些元函数,