草庐IT

boost_thread

全部标签

c++ - 试图摆脱 C++ boost 警告

每当我在我的项目中加入boost时,我都会收到一百万条这样的警告。有谁知道我怎样才能摆脱警告?../depends\boost/config/abi_prefix.hpp(19):warningC4103:'depends\boost\config\abi_prefix.hpp':alignmentchangedafterincludingheader,maybeduetomissing#pragmapack(pop)我知道我可以执行#pragma来禁用警告,但我想知道这些警告的原因。 最佳答案 原因是boost不会在每个需要打包数

c++ - 在 shared_from_this() 中 boost weak_ptr_cast

我正在使用boost的共享指针,并使用enable_shared_from_this来启用返回指向this的共享指针。代码如下所示:classfoo:publicboost::enable_shared_from_this{boost::shared_ptrget(){returnshared_from_this();}}为什么shared_from_this会抛出weak_ptr_cast异常? 最佳答案 如果您在堆栈上声明了foo,那么就没有其他指向foo的共享指针。例如:voidbar(){foofooby;fooby.get

C++,boost asio,接收空终止字符串

如何使用boost::asio库从套接字中检索以null结尾的字符串? 最佳答案 m_socket=boost::asio::ip::tcp::socket(io_service);boost::asio::streambufreplyBuf;......boost::asio::read_until(m_socket,replyBuf,'\0');如果你想将streambuf转换为字符串:std::stringretVal((std::istreambuf_iterator(&replyBuf)),std::istreambuf_

c++ - 如何为 boost::bind 强制模板函数重载?

我正在尝试通过使用boost::bind和boost::contains为std::find_if创建谓词(来自提升/算法/字符串库)。以下代码段显示了我如何尝试实现此目的的两种方式。#include#include#include#include#includeintmain(intargc,char**argv){std::strings1("hellomom");std::strings2("byemom");boost::functionf=&boost::contains;std::coutcontain_hello=boost::bind(boost::contains,_

c++ - boost shared_ptr 和 'this'

我有两个具有父子关系的类(客户&订单目录&文件等)我有typedefboost::shared_ptrParentPtr在父类中创建子类的方法我需要子实例有指向它们父实例的指针。classChild{....ParentPtrm_parent;....}我希望它是一个shared_ptr,这样在存在子项时父项不会消失。我还有其他人持有ParentPtrs给父级(Parents的工厂方法返回一个ParentPtr)问题:如何给child一个ParentPtr尝试(1)。在Parent::ChildFactorychild->m_parent.reset(this);这会导致非常糟糕的事情

c++ - Boost.Thread 还是::thread?

我还不是Boost用户。然而,我打算尽快进入它。然而,我不太关心Boost,以及future可能与即将推出的C++0x发生名称冲突或差异。(也许这不是一个真正的问题,但例如我发现boostlambdas语法非常丑陋,BOOST_FOREACH对眼睛有侵略性,以及其他仅个人审美观点)。我对TR2很感兴趣,它似乎是由库实现的Boost.Thread和just::thread.两者似乎都是由AnthonyWilliams编写和维护的。但是just::thread声称非常符合TR2。我想知道你们中是否有人会指示我使用一个或另一个。just::thread不是免费的,但如果它真的像TR2一样,我

c++ - 如何使用 boost.spirit 提取 std::string?

我尝试使用boost.spirit解析command:param1param2...形式的简单命令行为此我创建了这个解析器:(+(char_-':'))[ref(cmd)=_1]>>':'>>(*char_)[ref(params)=_1]这两个复合解析器的属性类型都是vector,所以如果cmd和params是vector类型就可以了。但是,如果它们是std::string类型,则不会。在网上搜索此解决方案时,我发现提示它也适用于字符串。无论如何我可以用字符串来完成这项工作吗? 最佳答案 当然,当您使用语义操作时,不会发生自动属性

c++ - 用 boost spirit 解析转义的字符串

我正在使用Spirit2.4,我想解析这样的结构:文本{text_field};要点是在text_field中是一个带有符号'{'、'}'和'\'的转义字符串。我想使用qi为此创建一个解析器。我一直在尝试这个:usingboost::spirit::standard::char_;usingboost::spirit::standard::string;usingqi::lexeme;usingqi::lit;qi::ruletext;qi::rulecontent;qi::ruleescChar;text%=lit("Text")>>'{'>>content>>"};";conten

c++ - boost::weak_ptr 过期后的排序顺序?

对于boost::weak_ptroperator被定义,以便它可以在关联容器中使用。我的问题是:几个weak_ptr的排序顺序是?即使其中一些对象的引用计数变为零,对象是否稳定?这不会与std::set这样的容器混淆吗??例子:usingnamespaceboost;shared_ptrsptrA1(newA);weak_ptrwptrA1=sptrA1;weak_ptrwptrA2;{//beginScope1shared_ptrsptrA2(newA);wptrA2=sptrA2;assert(wptrA1如果断言#1为真,断言#2是否始终为真?是wptrA2在范围1之前和之后处

c++ - 需要对 Boost asio 异步操作和计时器进行一些说明

异步连接中定时器有一个方面我想知道我是否理解正确。假设我们在执行读取操作之前设置了一个计时器,其中包括一个处理程序,然后,run()io_service。据我所知,io_service在管理器被调用后一结束就结束,这可能有两个原因:a)读操作完成。b)计时器已达到其限制。假设第一个(a)条件已经达到,并且在定时器结束前读操作已经完成。问题是:那个计时器会发生什么?我们需要完成它吗?说dTimer_.expires_from_now(boost::posix_time::seconds(0));aftertheio_service.run()?如果需要重新使用同一个计时器对象进行另一个读