草庐IT

BOOST-ASIO

全部标签

c++ - 如何将 boost::iostreams::mapped_file_source 与 gzip 压缩的输入文件一起使用

我正在使用boost::iostreams::mapped_file_source将文本文件从特定位置读取到特定位置并操作每一行(使用g++-Wall-O3-lboost_iostreams-otestmain.cpp编译):#include#include#includeintmain(){boost::iostreams::mapped_file_sourcef_read;f_read.open("in.txt");longlongintalignment_offset(0);//setthestartpointconstchar*pt_current(f_read.data()+

c++ - 具有 boost::multiprecision::mpfr_float 的 Eigen3 动态矩阵

我想制作矩阵并使用Eigen3库使用它们,我的数字类型是Boost.Multiprecision的mpfr_float包装器。我可以很好地制作矩阵,但是除了矩阵加法之外,我尝试过的所有操作都失败了。仅将两个单位矩阵相乘会产生垃圾结果!这是一个MWE:#include#include#include#includenamespaceEigen{usingboost::multiprecision::mpfr_float;templatestructNumTraits{typedefboost::multiprecision::mpfr_floatReal;typedefboost::mu

c++ - 是否对 boost 进行了优化以使用 C++11 中的可变参数模板?

我找不到关于(1)Boost是否已经在使用C++11的可变参数模板而不是使用MPL的版本中可用的信息,以及(2)在制作“典型”时可能期望减少什么样的编译时间在常见平台(MSVC2013、clang、gcc)上使用常见的Boost习语(ptr、tuple、pair、mutex等)。谢谢! 最佳答案 (Boost)Hana似乎是那个主动。许多子库选择只做他们的“下一个”版本c++11(Spirit、Fusion、Proto-0x和其他?)。所以如果你愿意的话,有一种远离MPL的运动。我不认为MPL在不久的将来会被“取代”。对于选择退出c

c++ - Boost序列化无法恢复保存的对象

这是我类(class)的样子:#include#include#include#include//includeheadersthatimplementaarchiveinsimpletextformat#include#include#includeusingnamespacestd;usingnamespaceboost;classouter{friendclassboost::serialization::access;public:inta;classinner{friendclassboost::serialization::access;public:inta;inner(

python - 带有函数模板的 Boost::Python 类:如何从外部添加实例?

总结有没有办法(在C++中,而不是在Python中)从外部为Boost::Python中的类添加函数模板的额外实例化(通过注入(inject)、重新打开定义、注册所需的实例化等)?背景给定一个包含函数模板成员的类(不是类模板),我想使用Boost::Python生成Python绑定(bind)。但是,由于我正在编写一个库,所以我事先并不知道成员函数将使用哪些模板参数进行调用。这意味着,我不能在Boost::Python类定义中列出它们。例子假设我们有一个类TheClass,它有函数模板(带重载),以及两个测试类SomeClass和OtherClass,如下所示:类定义#include#

c++ - 如何将 ostream 重定向到 Boost Log 库

我有一个进度条函数,它将std::ostream作为参数。出于描述的目的,我在这里对其进行了简化。voidsomeprogressbar(std::ostream&stream){stream我无法修改此功能,因为它是第三方功能。我用std::ostringstreammyoss;someprogressbar(myoss)调用这个函数或someprogressbar(std::cout).该函数会在我的程序进行时实时打印一些信息。如何将输出重定向到BoostLog库?我能做到BOOST_LOG_TRIVIAL(debug),但做不到someprogressbar(BOOST_LOG_

c++ - 根据报文序列号分发响应报文

我有一个第三方服务器,我正在为它写一个dll接口(interface),我的客户使用我的dll与服务器通信。该协议(protocol)使用长tcp连接,所有流量都来自此tcp连接。可能同时发送/接收多个数据包,比如同时发送send_msg和heart_beat,所以我必须使用async_write/async_read以防止阻塞操作。每个数据包都有其序列号。例如,我发送了一个序列号==123的消息,然后我应该等待服务器响应一个序列号==123的数据包。更新:不保证服务器按顺序响应数据包。如果两个数据包按A、B的顺序发送,响应顺序可能是response_B、response_A。序列ID

python - Boost.Python 多重返回参数

我有一个C++函数,它从它的参数返回多个值。voidDo_Something(doubleinput1,doubleinput2,doubleinput3,double&output1,double&output2){...output1=something;output2=something;}我想用Boost.Python包装这个函数。我想出了一个使用lambda的解决方案,但它有点乏味,因为我有许多函数在其参数中有多个返回值。BOOST_PYTHON_MODULE(mymodule){usingboost::python;def("Do_Something",+[](double

c++ - Boost 引用变体和相等性比较

以下程序中止:#includeusingvariant_type=boost::variant;intmain(){inta,b;variant_typev(a),u(b);v==u;return0;}与:$g++-std=c++14t.cpp&&./a.outa.out:/opt/boost/default/include/boost/variant/detail/forced_return.hpp:39:Tboost::detail::variant::forced_return()[withT=constint&]:Assertion`false'failed.Aborted(c

c++ - 使用 BOOST_FUSION_ADAPT_ADT 调整类时出错

我有以下类(class):#ifndefWFRACTAL_FRACTAL_METADATA_H_#defineWFRACTAL_FRACTAL_METADATA_H_#includenamespaceWFractal{namespaceFractal{classMetadata{public:voidsetAuthorName(conststd::string&name);voidsetAuthorEMail(conststd::string&email);voidsetBriefDescription(conststd::string&brief);voidsetCompleteDe