草庐IT

boost-lambda

全部标签

c++ - lambda 的生命周期在 const lambda 中捕获引用

我有以下API:old_operation(stream,format,varArgs);我想写一个适配器来编写调用如下:stream为此,我使用了一个临时对象,它存储对varArgs的引用并重载operator申请old_operation()如下:templatedecltype(auto)storage(T&&...t){return[&](auto&&f)->decltype(auto){returnstd::forward(f)(t...);};}templateclassOperation{usingStorage=decltype(storage(std::declval

c++ - 在移动的 lambda 中捕获和调试对局部变量引用的无效使用

在我的一个实际项目中,我遇到了一个难以调试的情况,我不小心访问了对已移动的lambda内部局部变量的引用。访问是从另一个线程完成的,但是移动的lambda一直保持事件状态,直到第二个线程完成。该错误仅在禁用优化时出现,并且是由粗心的重构引起的。我创建了一个最小示例(availablehereonwandbox)重现问题:structstate{intx=100;};templatevoideat1(TF&&f){//Callthelambda.f();//Simulatewaitingforthesecondthread//tofinish.std::this_thread::slee

python - boost::python:将 C++ 类暴露给嵌入在 C++ 应用程序中的 python 脚本

我在C++应用程序中使用boost::python成功加载了一个python脚本文件并调用了一个函数。在boostpython中EmbeddingPythonwiki上有关于howtoloadapythonmodule的提示.namespacebp=boost::python;bp::objectimport(conststd::string&module,conststd::string&path,bp::object&globals){bp::dictlocals;locals["module_name"]=module;locals["path"]=path;bp::exec("

C++ lambda 作为类方法

作为一个假设性的问题,我想使用lambdas作为类方法。我知道这在专业背景下是不好的,但我还是很好奇。一个例子可能最适合展示我想做什么。这是复数的基本类:classComplex{private:doublere,im;public:Complex():re(0.0),im(0.0){}Complex(doublere,doubleim):re(re*1.0),im(im*1.0){}Complex(constComplex&c)=default;~Complex()=default;functiongetRe=[=]()->double{returnre;};functionsetR

c++ - 函数参数评估顺序与 Lambda 捕获评估顺序

C++标准似乎函数参数求值的顺序以及lambda捕获初始值设定项的顺序未指定.(参见http://en.cppreference.com/w/cpp/language/lambda以及OrderofevaluationinC++functionparameters)这让我有些担心,因为它可能如何与move语义交互。假设我有一个T类型的对象,可能有一个抛出的复制或move构造函数。然后假设我有一个只能move的对象,例如std::promise。考虑以下情况:Tvalue;//sometypethatpotentiallythrowswhenmovedorcopiedpromisepr;

c++ - 将 boost 与 Visual Studio 和 vcpkg 链接时出错

我正在尝试完成一个简单的任务,以检查在Windows中开发“Linux应用程序”有多容易。我正在使用vcpkg来自Microsoft,以便设置header和库以及crow,一个使用boost作为驱动项目的c++http服务器来源很简单#include"crow.hpp"intmain(){crow::SimpleAppapp;CROW_ROUTE(app,"/")([](){return"Helloworld!";});app.port(18080).run();}我已经通过vcpkg下载了boost,并使用VisualStudio对项目进行了编码制作:cmake_minimum_re

c++ - boost::coroutine2 与 CoroutineTS

Boost::Coroutine2和CoroutineTS(C++20)是C++中流行的协程实现。两者都会挂起和恢复,但两种实现遵循完全不同的方法。协程TS(C++20)无堆栈返回暂停使用特殊关键字generatorGenerate(){co_yield;});boost::coroutine2堆叠通过电话暂停不要使用特殊关键字pull_typesource([](push_type&sink){sink();});有没有我应该只选择其中一个的特定用例? 最佳答案 主要的技术区别在于您是否希望能够从嵌套调用中退出。这不能使用无堆栈协

C++::Boost::Regex 迭代子匹配

我将命名捕获组与BoostRegex/Xpressive结合使用。我想遍历所有子匹配,并获取每个子匹配的值和KEY(即what["type"])。sregexpattern=sregex::compile("(?Phref|src)=\"(?P[^\"]+)\"");sregex_iteratorcur(web_buffer.begin(),web_buffer.end(),pattern);sregex_iteratorend;for(;cur!=end;++cur){smatchconst&what=*cur;//Iknowhowtoaccessusingastringkey:wh

c++ - C++中Boost Bimap的使用

C++Boost有一个双向映射的Bimap容器:http://www.boost.org/doc/libs/1_43_0/libs/bimap/doc/html/index.html有谁知道Boost::bimap的性能?我的意思是访问map中的元素的时间复杂度是多少?它与unordered_map访问一样快吗(O(1))?谢谢! 最佳答案 据我所知,该库的每个不同容器相对于实现(如STL容器)具有不同的操作复杂性。有关做出选择所需的详细信息,请阅读:http://www.boost.org/doc/libs/1_43_0/libs

c++ - boost::asio async_accept 拒绝连接

我的应用程序有一个asio服务器套接字,它必须接受来自定义的IP列表的连接。这个过滤器必须由应用程序完成,(而不是由系统),因为它可以随时更改(我必须能够随时更新此列表)客户端必须收到acces_denied错误。我想当handle_accept回调被调用时,SYN/ACK已经被发送,所以当我检测到连接的ipest不允许时不想接受然后粗暴地关闭。我不管理客户端行为,当连接被拒绝并被对等方关闭时,它的行为可能不一样,所以我想把所有事情都做干净。(但这就是我目前的目的)你知道我该怎么做吗???我的访问列表是std::strings的容器(但我可以将它转换成其他东西的计数器......)非常