草庐IT

hit-boosted

全部标签

c++ - 将 Boost FileSystem3 迭代器转换为 const char*

我正在使用BoostFileSystem3循环遍历目录中的一些文件,我需要将文件名转换为char*以用于另一个库,不幸的是我的C++foo缺失,任何人都可以帮忙吗?intmain(intargc,char*argv[]){pathp(argv[1]);//preadsclearerthanargv[1]inthefollowingcodetry{if(exists(p))//doespactuallyexist?{if(is_regular_file(p))//isparegularfile?coutvec;//storepaths,vecv;//sowecansortthemlate

c++ - boost::asio::async_write() 与 boost::asio::write()

在将数据缓冲区传输到线路上所花费的时间方面是否有任何优势如果你使用boost::asio::write(m_socket,asio::buffer(dataOut_,len),asio::transfer_all());代替boost::asio::async_write(m_socket,boost::asio::buffer(hbs,sizeof(hbs)),boost::bind(&Client::handle_pulse,this,boost::asio::placeholders::error,boost::asio::placeholders::bytes_transfer

c++ - Boost.Log 无法设置日志过滤器(未声明的标识符 'severity')

我正在努力让Boost.Log进入我的项目。问题出在这个简单示例的以下行中:usingnamespaceboost::log;core::get()->set_filter(trivial::severity>=trivial::info);在我的代码中,这转化为以下内容:boost::log::core::get()->set_filter(boost::log::trivial::severity>=boost::log::trivial::info);但是,我收到以下错误:errorC2039:'severity':isnotamemberof'boost::log::v2s_m

c++ - 当 -std=c++11 选项被删除时,clang++ 仅使用 boost::format 编译 C++11 程序

请看下面的C++11片段:#includeintmain(intargc,char**argv){autos=boost::format("");return0;}当我使用-std=c++11用clang编译它时,我得到以下错误:$clang++-std=c++11-omainmain.cppInfileincludedfrommain.cpp:1:Infileincludedfrom/usr/include/boost/format.hpp:19:Infileincludedfrom/usr/include/boost/detail/workaround.hpp:41:Infilei

c++ - 有没有更好的方法来检查是否存在 boost 共享内存段?

我能看到如何做到这一点的唯一方法是尝试访问它并捕获如果它不存在则抛出的异常。boolexists(){usingnamespaceboost::interprocess;try{managed_shared_memorysegment(open_only,kSharedMemorySegmentName);returnsegment.check_sanity();}catch(conststd::exception&ex){std::cout有没有更好的办法? 最佳答案 我在玩boost::interprocess时碰巧问了同样的问

c++ - 如何等待所有 boost 完成 :asio's stackful coroutines?

我正在用asio::spawn启动一些协程,我想等到所有协程都完成后再做一些其他工作。如何实现?控制流程如下:asio::spawn(io,[](asio::yield_contextyield){...//startingfewcoroutinesasio::spawn(yield,[](asio::yield_contextyield2){...});asio::spawn(yield,[](asio::yield_contextyield2){...});asio::spawn(yield,[](asio::yield_contextyield2){...});asio::spa

c++ - 静态成员和 boost 序列化

我正在使用Boost.Serialization归档类的内容。成员变量之一是静态std::vector。归档和恢复都很好,但我有点希望库只保存静态成员一次,看来,从文件大小来看,每个归档实例的静态成员都已完整保存。通过对静态vector使用set/getter并在类外部序列化静态vector一次,可以很容易地规避这一点。但我宁愿有一个独立的类(class)。是否有一种简单明了的方法来实现对类的静态内容仅归档一次? 最佳答案 在序列化所有类的实例之前序列化静态vector。如果你像这样序列化vector:templatevoidser

c++ - boost::asio::io_service 优先级如何工作?

我正在使用boost::asio::io_service来管理一些异步TCP通信。这意味着我创建了一个boost::asio::ip::tcp::socket并将io_service提供给它。当我开始交流时,它的示意图如下:异步解析->回调->异步连接->回调->异步写入->回调->异步读取我省略了resolve和bind等部分。假设套接字已绑定(bind)到端口并且主机名已解析(因此连接意味着建立到端点的真实连接)现在的重点是我可以使用相同的io_service对象启动多个异步连接。这意味着,例如,在我的io_service线程中,程序将要AsyncWrite一些数据,主线程将调用A

c++ - Boost.MPL 和类型列表生成

背景这是用于游戏引擎中的内存管理器。我有一个freelist实现,如果有的话,我想有一个编译时列表。(例如,MPL或fusionvector)。freelist对应分配大小,当分配/释放大小小于常量的对象时,它们将转到相应的freelist。最后,这意味着小对象在全局范围内具有摊销的恒定时间分配和恒定时间释放。(耶。)问题问题是生成我需要的类型,因此我最终可能会使用Fusion来实例化这些类型。使用的类型是(缩写等):templatestructdata_block{size_tmSize;//=NcharmData[N];};templateclassAllocator=std::a

c++ - boost::program_options 中带参数和不带参数的参数

我编写了一个使用boost::program_options进行命令行解析的小应用程序。如果参数存在,我希望有一些选项可以设置一个值,如果给出了参数但没有参数,则交替打印当前值。所以“设置模式”看起来像:dc-ctl--brightness15和“获取模式”将是:dc-ctl--brightnessbrightness=15问题是,我不知道如何在不捕获此异常的情况下处理第二种情况:error:requiredparameterismissingin'brightness'有没有一种简单的方法可以避免它抛出该错误?一旦参数被解析,它就会发生。 最佳答案