草庐IT

boost-move

全部标签

c++ - 在递归数据结构中 move unique_ptr<T> 数组

尝试编译以下代码会导致以下编译错误:errorC2280:'std::unique_ptr>::unique_ptr(conststd::unique_ptr>&)':attemptingtoreferenceadeletedfunction我的理解是数组“m_children”应该是可move的,因为unique_ptr指向的类型定义了move构造函数。除非这是由类的递归性质或我忽略的某些move语义元素引起的错误?#include#include#includeclassOctreeNode{public:OctreeNode(){};OctreeNode(OctreeNode&&

c++ - 如果在 user.hpp 中定义了 BOOST_NO_EXCEPTIONS,为什么不能编译 boost::shared_ptr

我有一个嵌入式系统,想在这个系统中使用boost,但需要禁用异常,因为我不想支付异常成本。boost给了一个user.hpp和可设置的宏选项BOOST_NO_EXCEPTIONS和BOOST_NO_EXCEPTION_STD_NAMESPACE,但是boost::shared_ptr不能编译(更准确的说,不能链接)如果定义了这两个宏。shared_ptr_boost.cpp:(.text._ZN5boost6detail12shared_countC2IiEEPT_[_ZN5boost6detail12shared_countC5IiEEPT_]+0x7a):undefinedrefe

c++ - boost::asio::streambuf - 如何重用缓冲区?

我正在实现使用asiosocket.async_read()和boost::asio::async_read_until()方法从套接字异步读取数据的TCP服务器。两者都使用相同的处理程序从boost::asio::streambuf读取数据。通过async_read()调用的完美处理程序:voidhandle_read(constboost::system::error_code&ec,std::size_tytes_transferred)){m_request_buffer.commit(bytes_transferred);boost::asio::streambuf::con

Python3、Boost-Python 和 Cpp 链接器错误

所以我打算把我的笔记本电脑扔出窗外,然后去烧掉AppleHQ。查看以下更新:我无法让python3、boost-python和clang相互协作。我遇到的错误正在运行:clang++-ohello.sohello.cpp调用响应:Undefinedsymbolsforarchitecturex86_64:"__Py_NoneStruct",referencedfrom:boost::python::api::object::object()inhello-0c512e.o"_main",referencedfrom:implicitentry/startformainexecutabl

c++ - 从自身内部替换 std::function(通过 move 赋值到 *this?)

是否可以用另一个std::function替换一个std::function?以下代码无法编译:#include#includeintmain(){std::functionfunc=[](){std::cout可以修改编译吗?现在的错误消息是:'this'wasnotcapturedforthislambdafunction-我完全理解。但是,我不知道如何捕获func的this指针。我想,它甚至不是lambda中的std::function吧?!如何做到这一点?背景:我想要实现的是:在给定std::function的第一次调用中,我想做一些初始化工作然后替换具有优化功能的原始功能。我

c++ - 为什么没有 std::move_n 算法?

我假设有一个std::copy_n这样就可以与输入迭代器一起使用。出于同样的原因没有std::move_n是否有某种原因? 最佳答案 我认为答案可能很平凡。std::copy永远存在,它是C++03中唯一的算法。N1377(2002)在语言中添加了移动语义,还引入了算法std::move()和std::move_backward()以反射(reflect)现有的std::copy()和std::copy_backward()。这些是唯一存在的复制算法-因此它们是唯一获得move版本的算法。N2569(2008)添加了更多算法,其中大

c++ - 如何用数据创建一个boost线程?

我在使用boost::bind和创建线程时遇到了一些问题。本质上,我想在“扫描仪”对象上调用“扫描”函数,使用绑定(bind)。像这样:Scannerscanner;intid_to_scan=1;boost::threadthr1(boost::bind(&scanner::scan));但是,我在语法上被绊倒了。如何将数据传递给扫描?作为构造函数的一部分? 最佳答案 请记住,任何成员函数的第一个参数都是对象。所以如果你想调用:scanner*s;s->scan()对于bind你会使用:boost::bind(&scanner::

c++ - 将带有 Boost 的 C++ 应用程序从 Linux 移动到带有 Visual Studio 6 的 Windows

2年前,我在Linux中使用Boost编写了一个小程序。现在我想让它在Windows中工作。我发现我的libs文件夹中几乎没有.a文件。我想知道如何让它在Windows中工作?我需要在Windows中构建Boost来获取库还是可以在某处下载?我正在使用VisualStudio6。 最佳答案 是的,您需要针对不同的平台重新编译。巧合的是,我在这个notlongago上发布了说明.我非常建议您不要使用VisualStudio6。它非常过时,而且非常不合规。您可以免费获得较新的版本,如Express。您不会错过任何东西。

c++ - std::move 会导致切片吗?

例如,在unique_ptr=newderiv;std::vector>.push_back(std::move(deriv));将deriv切片为类型unique_ptr? 最佳答案 不会发生切片;unique_ptr将拥有指向Derived的指针对象。Aunique_ptr派生类可以隐式转换为unique_ptr到基类。 关于c++-std::move会导致切片吗?,我们在StackOverflow上找到一个类似的问题: https://stackover

c++ - Boost序列化断言失败

我使用boost的二进制序列化,直到现在它运行良好。我有std::list指向序列化输出(oarchive)的指针,但序列化在对象的serialize()函数中失败,带有MSVC的对话框:R6010-abort()hasbeencalled这样的字符串被打印到控制台窗口中:Assertionfailed:0==static_cast(t)||1==static_cast(t),filec:\programfiles\boost\boost_1_44\boost\archive\basic_binary_oprimitive.hpp,line91这是什么意思?项目非常大,资源是分布式的,