草庐IT

boosting

全部标签

c++ - 如果 boost::thread 创建线程失败,它会做什么?

如果创建线程失败,boost::thread会做什么?winAPI返回NULL(我猜posix做了类似的事情)但是由于线程是一个对象,我该如何测试线程是否已创建? 最佳答案 根据API,如果线程创建失败,它会抛出一个boost::thread_resource_error。我猜你不能创建一个无效的boost::thread对象:如果出现问题,构造函数会抛出异常从而阻止对象的创建。 关于c++-如果boost::thread创建线程失败,它会做什么?,我们在StackOverflow上找到

c++ - 访问 boost::tuple 的成员

我正在尝试实现一个vector,例如vector>day;我想访问元组的第一个元素来检查条件。有人可以告诉我该怎么做吗?我是新来的。提前致谢。 最佳答案 #include#include#includeintmain(){std::vector>v;v.push_back(boost::make_tuple(1,2,3));std::cout(v[0])(v[0])(v[0]) 关于c++-访问boost::tuple的成员,我们在StackOverflow上找到一个类似的问题:

c++ - boost 测试 - 'undefined reference' 错误

我有两个简单的文件:运行者.cpp:#defineBOOST_TEST_DYN_LINK#defineBOOST_TEST_MODULEMain#include和test1.cpp:#defineBOOST_TEST_DYN_LINK#ifdefSTAND_ALONE#defineBOOST_TEST_MODULEMain#endif#includeBOOST_AUTO_TEST_SUITE(Foo)BOOST_AUTO_TEST_CASE(TestSomething){BOOST_CHECK(true);}BOOST_AUTO_TEST_SUITE_END()为了编译,我正在使用:$

c++ - 序列化原始 boost::variant 是否安全?

boost::variant声称它是一个值类型。这是否意味着简单地写出boost::variant的原始表示并稍后加载它是安全的,只要它只包含POD类型?假设它将由相同编译器和相同版本的boost在相同架构上编译的代码重新加载。此外,(可能)等价地,可以在共享内存中使用boost::variant吗? 最佳答案 尝试只包含boost/serialization/variant.hpp;它会为您完成工作。 关于c++-序列化原始boost::variant是否安全?,我们在StackOve

c++ - boost::asio async_read 保证读取所有字节

我有一个服务器从客户端接收压缩字符串(用zlib压缩),我使用的是async_receive来自boost::asio库来接收这个字符串,但事实证明不能保证所有字节都将被接收,所以我现在必须将它更改为async_read.我面临的问题是接收到的字节大小是可变的,所以我不确定如何使用async_read不知道要接收的字节数。随着async_receive我只有一个boost::array,然而这是一个不一定完全填满的缓冲区。我想知道是否有人可以建议一个解决方案,即使我不知道要提前接收的字节数,我也可以使用async_read?voidtcp_connection::start(boost

c++ - boost 的正则表达式无法编译

我在Ubuntu上使用boost1.45.0,Code::Blocks作为我的IDE,但我无法编译basic_regex.hpp。我很确定我正确设置了boost,因为我可以使用boost::format编译程序而不会出现任何错误。但是我遇到了这个烦人的错误,我不知道如何摆脱它。引发错误的代码:boost::regexe("\"http:\\\\/\\\\/localhostr.com\\\\/files\\\\/.+?\"");编译器输出(GCC):obj/Debug/main.oInfunction`boost::basic_regex>>::assign(charconst*,ch

c++ - 如何检查套接字是否在 Boost.Asio 中关闭?

检查远程连接端的套接字是否关闭的最简单方法是什么?socket::is_open()返回true,即使它在远程端关闭(我正在使用boost::asio::ip::tcp::socket).我可以尝试从流中读取并查看它是否成功,但我必须更改我的程序逻辑以使其以这种方式工作(我不希望此时从流中提取数据支票)。 最佳答案 只需在您的async_receive处理程序中检查boost::asio::error::eof错误。这意味着连接已关闭。这是唯一正确的方法。 关于c++-如何检查套接字是否

[②C++ Boost]: Boost库编译,arm交叉编译方法

前言Boost是十分实用的C++库,如果想在arm环境下使用,就需要自己下载源码编译,本篇博客就记录下Boost库的编译方法。下载Boost源码Boost源码的下载路径可以使用:https://sourceforge.net/projects/boost/files/boost/编译例如博主这里下载的版本是boost_1_66_0.7z,下载完成解压缩后进入boost_1_66_0文件夹,可以用以下命令查看编译选项:./bootstrap.sh--help可以用以下命令查看Boost可以编译的库:./bootstrap.sh--show-libraries例如我们只想编译program_opt

C++之光:std库与Boost库的优美默契合作

在C++开发的领域,我们常常听说std库和Boost库这两个神秘而强大的存在。它们之间的关系如何?它们如何共同助力我们编写更出色的代码?一、C++标准库(std):基石中的巨人C++标准库,也被称为STL(StandardTemplateLibrary),是每个C++开发者的得力助手。它是C++标准委员会定义的,提供了一系列强大而通用的工具,让我们能够更轻松地开发出高效的应用。1.容器:数据结构的精华让我们先来看看std库中的容器。以vector为例,它是一个动态数组,可以自动调整大小,让我们可以高效地存储和操作数据。比如:#include#includeintmain(){std::vect

c++ - boost iOS 链接错误

我有一个C++库,它在很大程度上依赖于我正在尝试为iOS8编译的boost。我使用DanielRosser的脚本为iOS编译了boost-1.57.0:https://github.com/danoli3/ofxiOSBoost我修改了脚本,使其也构建了boost的序列化库,一切看起来都很好。但是,当我在XCode中编译我的库时,我得到:Undefinedsymbolsforarchitecturex86_64:"boost::archive::detail::shared_ptr_helper::shared_ptr_helper()",referencedfrom:eos::por