草庐IT

hit-boosted

全部标签

c++ - 无法在 boost 1.57 中编译 boost/any_iterator.hpp

在(尝试)升级VS2012项目以使用boost1.57之后,我无法再编译——boost/any_iterator.hpp中出现大量错误消息(见下文)。作为测试,我创建了一个新项目,其中只包含一个空的主函数和#include"boost/any_iterator.hpp"并得到了相同的错误集。这是它提示的代码://snippetfromboost/any_iterator.hpptemplateclasspostfix_increment_proxy>{//...};同一文件中还有另一个类遵循相同的模式并生成相同的错误。range_detail::any_iterator在文件中稍高一点

c++ - boost::optional 对 bool 的隐式转换消失了吗?

我开始将vc++10/boost1.48代码库移植到vc++12/boost1.57,但我收到一个错误,提示boost::optional无法转换为bool。我以为这是boost::optional的一个特性,它被删除了吗?例子:boolfizz(){boost::optionalbuzz;returnbuzz;}给予Error21errorC2440:'return':cannotconvertfrom'boost::optional'to'bool' 最佳答案 是的。Boost1.55仍然使用SafeBoolIdiom://im

c++ - boost optional 和 std::experimental optional assignment 之间的区别

通常当函数返回boost::optional时我见过很多人返回空括号{}指定一个空值,它工作正常并且比返回boost::none短.我尝试做一些类似于清空boost::optional的事情,但是当调用复制赋值运算符(或者很可能是移动赋值运算符)并在右侧使用空大括号时,空大括号被转换为int然后将该值分配给可选值,所以我最终得到变量设置为0而不是我预期的空值。这是一个例子https://godbolt.org/g/HiF92v,如果我用std::experimental::optional做同样的尝试我得到了我期望的结果(只需在示例中替换为std::experimental::opti

c++ - 为什么 boost 正则表达式 '.{2}' 不匹配 '??'

如果数据流中的有趣数据,我正在尝试匹配一些block。应该有一个前导然后是四个字母数字字符、两个校验和字符(或??如果未指定shecksum)和尾随>.如果最后两个字符是字母数字,则以下代码按预期工作。如果他们是??尽管它失败了。//Setupapre-populateddatabufferasanexamplestd::stringhaystack="Flibble";//Setuptheregexstaticconstboost::regexe("");std::string::const_iteratorstart,end;start=haystack.begin();end=h

c++ - boost::ifind_first 与 std::string 对象

我正在尝试使用boost字符串算法进行不区分大小写的搜索。这里是新手。如果我以这种方式使用它,我会得到一个错误。std::stringstr1("Helloworld");std::stringstr2("hello");if(boost::ifind_first(str1,str2))somecode;转换为char指针可以解决问题。boost::ifind_first((char*)str1.c_str(),(char*)str2.c_str());有没有办法直接搜索std::string对象?此外,也许还有另一种方法可以通过不区分大小写的搜索来了解字符串是否存在于另一个字符串中?

c++ - Boost.Any 获取原始类型

我需要将any变量转换为原始类型。我需要这样做:inti=10;anya(i);int&i2=any_cast(a);但我希望类型存储在any变量中。我这样写:inti=10;anya(i);a::type_value&i2=any_cast(a);//thereisnoactuallytype_value我怎样才能做这样的事情?或者如何从any变量中提取原始类型?Boost.variant也很方便。如果我做不到,那么我还有一个问题,有什么C++技术和库可以通过函数存储和获取类型来解决这个问题? 最佳答案 C++是一种静态类型的语言

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