草庐IT

Boost-asio

全部标签

c++ - 为什么 boost::enable_if 不会导致重复重载方法编译错误

我已经获得了enable_if的代码,它允许我做一些很棒的事情,但我认为它会导致错误,因为我下面显示的两个方法具有相同的方法签名。有人知道为什么允许这样做吗?#include#includetemplatestructenable_if{typedefRtype;};templatestructenable_if{};templatetypenameenable_if::value>::typeprint(constT&item){std::couttypenameenable_if::value)>::typeprint(constT&item){std::cout

c++ - boost 图中的颜色图 breadth_first_visit

我想使用boostsbreadth_first_visit方法,我想为它提供我自己的“外部”颜色图。我定义的图如下typedefboost::adjacency_list>>GraphType;其中Node_t是一个结构体,用于定义顶点的属性。但是,我无法找到如何为BFS提供我自己的颜色图。我想将顶点颜色存储在一个vector中,所以我的定义看起来像std::vectorcolors;但我想不通,如何将其用于bfs。都不是boost::breadth_first_search(g,*boost::vertices(g).first,boost::color_map(colors));也

c++ - boost.proto + 就地修改表达式树

背景问题:boost.proto+detectinvalidterminalbeforebuildingtheexpressiontree.你好,我想实现的是创建表达式树的拷贝,其中所有vector都替换为他们的开始迭代器(在我的例子中是一个原始指针)就地增加迭代器解引用树中的迭代器,但这部分应该相对容易。所以,对于1。我最终得到了这段代码/////////////////////////////////////////////////////////////////////////////////Atransformthatconvertsallvectorsnodesinatree

c++ - 包装一个 Boost.Fusion 序列

我正在寻找一种方法来创建Boost.Fusion序列包装器,它本身就是一个Fusion序列,并将所有“调用”转发到它的包装序列。行内的东西templatestructsequence_wrapper{explicitsequence_wrapper(Sequenceconst&s):seq(s){}Sequenceseq;};哪里sequence_wrapper也是一个Fusion序列,并且与Sequence一样工作将。我需要这个的原因是我有几个函数可以在Fusion序列上运行(其中所有元素都满足一些特殊要求),我想添加一些语法糖,我需要一个自定义类型来将重载运算符添加到。我不需要对s

c++ - 静态 boost::wregex 实例是线程安全的吗?

用固定的boost::wregex声明一个静态/全局变量然后在多个线程中使用它而不用担心正则表达式的内部状态(如果Boost是用BOOST_HAS_THREADS编译的)是否安全?例如boost::wregexg_regex(L"common|test");然后有多个线程调用:if(boost::regex_search(test_str,g_regex))... 最佳答案 http://www.boost.org/doc/libs/1_51_0/libs/regex/doc/html/boost_regex/background_

c++ - Boost Python 的性能

我正在做一个项目,在这个项目中我正在试验boostpython。在研究如何组织我的python界面时,我遇到了comment断言boostpython存在性能问题。它的性能有任何实际问题吗?在这种情况下,我正在处理一个大型项目,我们希望将其中的一部分公开给python。我发现boostpython可以很容易地公开我已经拥有的类。所以我宁愿坚持使用boostpython公开类的方法,因为它非常简单。除非有人有同样易于使用和高性能的替代方案。 最佳答案 我们正在使用boost::python将一个大型计算机视觉库集成到一个高度可配置的软

c++ - boost::any 的访客模式

我找到了这个https://gist.github.com/2945472但我需要一个不依赖于c++11的实现。我尝试将其转换为仅使用boost,但遇到了一些麻烦。这是我想出的:#include#include#include#include#includestructtype_info_hash{std::size_toperator()(std::type_infoconst&t)const{returnt.hash_code();}};structequal_ref{templatebooloperator()(boost::reference_wrappera,boost::r

c++ - 如何在 x86 和 x64 平台之间使用 boost::serialization

我有一个在Windows下作为64位应用程序运行的程序。我想要同一个程序作为32位应用程序工作。它可以编译、链接和运行,但我无法在32位应用程序中读取我用64位应用程序存储的文件。我使用带有二进制存档的boost::serialization来写入和读取文件。该软件已经发布给客户。客户端应该能够使用32位应用程序读取64位应用程序存储的文件。这可能吗?如何?有经验吗? 最佳答案 您可以编写一个64位应用程序,将二进制存档转换为xml存档。这些您可能可以使用32位应用程序阅读并转换为您选择的格式。

c++ - Boost IO Stream 和 ZLib 提速

我有一个大文件,我使用Zlib使用boostIOStreams和过滤流缓冲区压缩了数据:boost::iostreams::array_sourceuncompressedArray(reinterpret_cast(&uncompressedData[0]),uncompressedData.size());boost::iostreams::filtering_streambufout;out.push(*m_compressor);out.push(boost::iostreams::char_back_inserter(compressedData));boost::iostr

C++ 性能 : template vs boost. 任何

我想知道在任何可以使用模板的地方使用boost.any(没有RTTI)类是否会减慢程序速度。由于boostany实际上是模板类的包装器,可以说现代编译器优化会产生相同的效果,对吗?tpl_vs_any.hpp#include#includeusingnamespacestd;templateclasstpl{Tcontent;public:tpl(constT&value):content(value){}operatorT()const{returncontent;}};classany{public:any():content(0){}any(constany&other):con