草庐IT

boost-move

全部标签

c++ - 为什么 boost::filesystem::path::string() 在 Windows 上按值返回,而在 POSIX 上按引用返回?

来自boost/filesystem/path.hpp:#ifdefBOOST_WINDOWS_APIconststd::stringstring()const{[...]}#else//BOOST_POSIX_API//string_typeisstd::string,sothereisnoconversionconststd::string&string()const{returnm_pathname;}[...]#endif对于wstring()来说恰恰相反——在Windows上通过引用返回,在POSIX上通过值返回。这有什么有趣的原因吗? 最佳答案

c++ - move 的对象仍然被破坏?

在学习C++11时,我对move对象的行为方式感到惊讶。考虑这段代码:#include#include#includeclassMoveable{public:Moveable(){std::cout::value,"isnotcopyconstructible");static_assert(!std::is_copy_assignable::value,"isnotcopyassignable");static_assert(std::is_move_constructible::value,"ismoveconstructible");static_assert(std::is_

c++ - 运行 boost bcp 工具时出错 : "The Boost path appears to have been incorrectly set"

尝试运行Boost的bcp工具时,出现以下错误:****exception(205):std::runtime_error:TheBoostpathappearstohavebeenincorrectlyset:couldnotfindboost/version.hppin********errorsdetected;seestandardoutputfordetails********错误消息与上面完全一样,它尝试搜索的路径为空。我尝试通过设置BOOST_ROOT环境变量来解决它,但同样的错误又回来了,搜索到的路径仍然是空的。系统为MacOSX10.9.1。

c++ - Boost 无法从演示中找到 future::then

那时我想尝试boostfuture,我安装了boost1.55并包含在make文件中,我想尝试官方演示#defineBOOST_THREAD_PROVIDES_FUTURE#includeusingnamespaceboost;intmain(){futuref1=async([](){return123;});futuref2=f1.then([](futuref){returnf.get();});//here.get()won'tblock});}但是编译的时候总是报错error:‘classboost::future’hasnomembernamed‘then’当我用f2注释行

c++ - 返回 const 值以利用 move 语义与防止诸如 (a+b)=c 之类的东西

这个问题在这里已经有了答案:Isn'ttheconstmodifierhereunnecessary?[duplicate](5个答案)关闭8年前。我认为thisquestion有点被误解了。返回const值并不是可以被视为无意义的东西。正如AdamBurry在评论中指出的那样,ScottMeyers在更有效的C++(第6项)中推荐了它,我将向其中添加HerbSutter的ExceptionalC++(第20项,类力学,其对应的GotW为availableonline)。这样做的基本原理是您希望编译器捕获像(a+b)=c(哎呀,意思是==)这样的拼写错误,或误导性语句像a++++,这两

c++ - 在 C++11 中实现 boost::optional

我正在尝试使用C++11特性实现类似boost::optional的数据结构。这是我到目前为止所拥有的:templatestructmaybe{boolvalid;union{Tvalue;};maybe():valid(false){}maybe(constT&_v){valid=true;new(&value)T(_v);}maybe(constmaybe&other){if(other.valid){valid=true;new(&value)T(other.value);}elsevalid=false;}~maybe(){if(valid)value.~T();}boolis

c++ - Boost 1.59.0 如何清理项目?

我构建了一次项目,所以它生成了一堆.o和.a文件。现在,我正在尝试清理它。本页:http://www.boost.org/build/doc/html/bbv2/overview/invocation.html告诉我b2--clean-all或b2clean应该有效。不过,我试过了:b2cleanb2--cleanb2--clean-all他们似乎都没有做任何事情。如何清理boost工作区? 最佳答案 如果将-n与--clean-all一起使用,报告它将运行的命令,如:b2--clean-all-n然后我确实看到像往常一样打扫干净的

c++ - Qt 是否有自己的 boost::optional 替代方案?

Qt是否有自己的boost::optional替代方案,还是我应该只使用boost::optional? 最佳答案 Qt有一个“变体”类型,但没有“可选”类型。我认为boost::optional(或者,在较新的C++版本中,std::optional)是一个合理的选择。 关于c++-Qt是否有自己的boost::optional替代方案?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questi

c++ - std::move 与 std::make_pair

有什么区别:std::map>m;Tt1,t2;m.emplace(1,std::make_pair(t1,t2));和:std::map>m;Tt1,t2;m.emplace(1,std::move(std::make_pair(t1,t2)));std::move在这里是多余的吗?std::map::emplace和perfectforwarding是否负责直接在std::中分配std::pairmap? 最佳答案 std::make_pair(...)和std::move(std::make_pair(...))都是右值表达式

c++ - boost asio 和 coroutine2 示例

在阅读coroutine2的文档时,我发现了一个不错的snippet显示如何将其与asio一起使用的代码引用文档中的代码:voidsession(boost::asio::io_service&io_service){//constructTCP-socketfromio_serviceboost::asio::ip::tcp::socketsocket(io_service);try{for(;;){//localdata-bufferchardata[max_length];boost::system::error_codeec;//readasynchronousdatafrom