草庐IT

boost-move

全部标签

python - boost::python 可以将对象的所有权传递给 python 回调函数吗?

我目前正在使用boost::python::call将C++指针传递给python回调函数功能。这工作正常,但如果我随后不删除C++代码中的指针,就会引入内存泄漏。我想将指针传递给回调并让python的垃圾收集器处理对象的生命周期。现在,如果我想保存传递给回调的对象,我必须进行深拷贝。我看过here使用return_value_policy包装的C++函数的返回值可能会发生这种情况.是否可以对boost::python::call的参数做类似的事情?? 最佳答案 方式manage_new_object工作原理是作为一个元函数类,将参

c++ - 使用boost线程的多线程中的段错误(核心转储)

当尝试使用最多1个线程运行我的程序时,它可以正常工作一段时间(几秒或几分钟)但最终出现段错误(核心转储)或双重释放(faststop)错误。这里是线程运行的函数。//usedintheFunction[Added]typedeffolly::ProducerConsumerQueuePcapTask;structs_EntryItem{Columns*p_packet;//hassomearbitrarymethodandvariablesboost::mutex_mtx;};//_buffersConnection.wait_and_pop()Datawait_and_pop(){b

c++ - 使用来自 Boost.Spirit 的 Lex 和 Qi 在语法规则中使用词法分析器标记属性

让我们考虑以下代码:#include#include#include#include#include#include#include#includenamespacelex=boost::spirit::lex;namespaceqi=boost::spirit::qi;namespacephoenix=boost::phoenix;structoperation{enumtype{add,sub,mul,div};};templateclassexpression_lexer:publiclex::lexer{public:typedeflex::token_defoperator_

c++ - lambda 函数不是 throw_move_assignable 吗?

clang-cl(4.0.0-trunk)似乎认为是,而vc2015(update3)认为不是。此实现是否已定义或标准是否规定了lambda函数应如何在术语或nothrow和moveassignable中实现?#include#includetemplatevoidtest_nothrow_move_assignable(T&&){std::cout::value 最佳答案 这是clang错误。来自[expr.prim.lambda]:Theclosuretypeassociatedwithalambda-expressionhas

c++ - 如何在等待时取消 `boost::asio::read` 操作

我正在使用boost::asio在客户端和服务器之间来回传输数据。我在客户端有一个读取器线程来读取客户端套接字上接收到的数据。请注意,我在客户端使用boost::asio::read,在服务器端使用boost::asio::write。不使用async_read或async_write。一切都很好。但是,当我关闭我的应用程序时,10次中有2次该应用程序没有完全关闭或正确关闭。关闭时挂起问题如下:我的关闭函数在我的应用程序关闭期间调用析构函数时被调用。以下是关闭函数的代码:socket.cancel();socket.close();boost::system::error_codeec

c++ - 如何从 boost 属性树中读取字段类型

我正在使用boost属性树从json文件中读取值。{"some_values":{"field_1":"value_1","field_2":true}}我可以读取值:spTree->get("some_values.field_1","");spTree->get("some_values.field_2",false);但是我可以读取存储在任何给定字段中的变量类型吗? 最佳答案 Documentationsays[...]thefollowingJSON/propertytreemappingisused:[...]JSONva

c++ - 如何同时迭代两个 Boost 预处理器序列?

我想知道是否可以通过Boost预处理器序列完成以下操作。(大多数SO问题以及Boost预处理器示例仅讨论1个序列)#defineseq1(a)(b)(c)#defineseq2(1)(2)(3)//Nowiterateoverbothofthematthesametime这是我的动力。我必须为很多类型定义一些函数,例如voidadd(intval){obj.AddInt(val);}voidadd(doubleval){obj.AddDouble(val);}我正在考虑定义两个序列,例如#definetypes(int)(double)...#definefuncs(AddInt)(A

c++ - 为什么 std::allocator 要求 propagate_on_container_move_assignment 为真?

根据当前标准(20.7.9),std::allocator有一个成员propagate_on_container_move_assignment设置为true_type:templateclassallocator{public:typedefsize_tsize_type;typedefptrdiff_tdifference_type;typedefT*pointer;typedefconstT*const_pointer;typedefT&reference;typedefconstT&const_reference;typedefTvalue_type;templatestruc

c++ - 如何在 Boost.Spirit 中跳过行/ block /嵌套 block 注释?

在使用Boost.Spirit解析语言时,如何保证跳过//linecomments/*blockcomments*/and/*/*nestedblock*/comments*/在阅读代码时?目前,我只是将phrase_parse转换为预定义的qi::grammar。我想我需要的是某种跳过词法分析器,对吧? 最佳答案 不需要词法分析器。这是一个实现它的示例语法:Cross-platformwaytogetlinenumberofanINIfilewheregivenoptionwasfound,但无论如何您都可以使用这样的skippe

c++ - boost::filesystem 递归获取每个文件的大小

当参数是目录时,为什么这段代码会抛出错误?使用boost::recursive_directory_iterator和使用std::cout语句,我可以看到它从不打印目录;只有文件。但是,当我尝试调用boost::filesystem::file_size()时,会抛出一个错误,基本上是说我正在尝试获取目录的文件大小。错误(参数是"/home"):terminatecalledafterthrowinganinstanceof'boost::filesystem::filesystem_error'what():boost::filesystem::file_size:Operatio