草庐IT

boost_process

全部标签

c++ - boost::asio::buffer:获取缓冲区大小并防止缓冲区溢出?

我有以下两个发送和接收数据包的函数。voidsend(std::stringprotocol){char*request=newchar[protocol.size()+1];request[protocol.size()]=0;memcpy(request,protocol.c_str(),protocol.size());request_length=std::strlen(request);boost::asio::write(s,boost::asio::buffer(request,request_length));}voidreceive(){charreply[max_l

c++ - 如何使用 stdlibc++ 为 OS X 64b 平台编译 boost?

我想使用stdlibc++为MacOSX10.9编译boost。我运行以下命令:./b2threading=multilink=staticruntime-link=staticcxxflags="-stdlib=libstdc++"linkflags="-stdlib=libstdc++"构建成功完成;但是,我的应用程序构建在链接时失败,因为它找不到像std::__1::locale::use_facet、std::__1::basic_string等那样糟糕的符号。我相信相关的细节是__1。我的问题是,如何使用stdlibc++为OSX64b平台编译boost?更多信息:我在编译过

c++ - 使用 boost::asio::streambuf

寻找boost::asio(以及自己的boost)决定编写异步服务器。为了存储传入数据,我使用boost::asio::streambuf。在这里我有一个问题。当我收到来自客户端的第二条消息和随后的消息时,我看到缓冲区中包含来自先前消息的数据。尽管我在输入缓冲区调用了Consume方法。怎么了?classtcp_connection//Usingshared_ptrandenable_shared_from_this//becausewewanttokeepthetcp_connectionobjectalive//aslongasthereisanoperationthatrefer

c++ - const std::map<boost::tuples::tuple, std::string>?

//BOOSTIncludes#include//Boost::Assign#include//Boost::Assign::List_Of#include//Boost::Assign::Map_List_Of#include//Boost::Tuples//STDIncludes#include#include#include//Usingnamespacesusingnamespacestd;usingnamespaceboost;usingnamespaceboost::assign;//Constsconstmapquery_map=map_list_of("4556_SEL

c++ - 初始化 boost::scoped_ptr 数组的正确方法?

我有一个类,其中有一个范围指针数组,这些指针指向没有默认构造函数的对象。我发现“初始化”它们的唯一方法是像这样使用swap():classBar{Bar(char*message){};}classFoo{boost::scoped_ptrarr[2];Foo(){arr[0].swap(boost::scoped_ptr(newBar("ABC")));arr[1].swap(boost::scoped_ptr(newBar("DEF")));};}这感觉有点冗长和笨拙。我错过了更聪明的方法吗? 最佳答案 arr[0].reset

c++ - boost 字符串拆分以消除单词中的空格

我编写了这段代码,将包含带有许多空格和/或制表符的单词的字符串拆分为仅包含单词的字符串vector。#include#include#include#includeintmain(){usingnamespacestd;stringstr("cONtainSSoMeCApiTaLWORDS");vectorstrVec;usingboost::is_any_of;boost::algorithm::split(strVec,str,is_any_of("\t"));vector::iteratori;for(i=strVec.begin();i!=strVec.end();i++)co

c++ - 我应该先学习哪个: Boost or Qt

Asitcurrentlystands,thisquestionisnotagoodfitforourQ&Aformat.Weexpectanswerstobesupportedbyfacts,references,orexpertise,butthisquestionwilllikelysolicitdebate,arguments,polling,orextendeddiscussion.Ifyoufeelthatthisquestioncanbeimprovedandpossiblyreopened,visitthehelpcenter提供指导。9年前关闭。我主要是一名业余程序员

c++ - 使用 boost::singleton_pool 时处理 std::string/std::vector 成员变量

我正在编写一个性能关键型应用程序,我在其中创建了大量类似类型的对象来下订单。我正在使用boost::singleton_pool用于分配内存。最后我的类看起来像这样。classMyOrder{std::vectorv1_;std::vectorv2_;std::strings1_;std::strings2_;public:MyOrder(conststd::string&s1,conststd::string&s2):s1_(s1),s2_(s2){}~MyOrder(){}staticvoid*operatornew(size_tsize);staticvoidoperatorde

C++/Boost MPL : structure code likewise Haskell's let, 其中,

由于C++元编程是函数式的:是否有任何方法可以与任何函数式编程语言(例如Haskell的)的let或where构造相媲美?我正在使用Boost::MPL,但希望为更长的元函数提供更多结构。拆分成几个函数很好,但在某些情况下我更喜欢let/where。 最佳答案 MPL本身不支持let子句,但一些构建在它之上的库支持。一个例子是metamonad.顾名思义,它还支持其他一些更高级别的功能概念(monad)。一个很大的缺点是,metamonad不是Boost发行版的官方部分。就MPL的变通方案而言,将事物拆分为函数并使用更多命名空间对它

c++ - 使用 Boost Asio 设置帖子队列大小限制?

我正在使用boost::asio::io_service作为基本线程池。一些线程被添加到io_service,主线程开始发布处理程序,工作线程开始运行处理程序,一切都结束了。到目前为止,一切都很好;与单线程代码相比,我获得了不错的加速。但是,主线程有数百万的东西要发布。它只是不断地发布它们,比工作线程处理它们的速度快得多。我没有达到RAM限制,但将这么多东西排入队列仍然有点愚蠢。我想要做的是为处理程序队列设置一个固定大小,并在队列已满时阻止post()。我在BoostASIO文档中没有看到任何选项。这可能吗? 最佳答案 我正在使用信