草庐IT

lambda_sync

全部标签

c++ - 将 lambda 转换为 std::tr1::function

使用带有tr1服务包和IntelC++编译器11.1.071[IA-32]的visualstudio2008,这与我的其他相关question我正在尝试为c++编写一个功能映射,它的工作方式有点像ruby​​版本strings=[2,4].map{|e|e.to_s}所以我在VlcFunctional命名空间中定义了以下函数templatevectormap(constContainer&container,std::tr1::functionf){vectortransformedValues(container.size());intindex=-1;BOOST_FOREACH(c

c++ - std::forward of rvalue ref to lambda?

考虑以下两个片段:附件A:templateintperform_calc(CalcFuncT&&calcfunc){precalc();intconstcalc=calcfunc();postcalc();returncalc;}intmain(){perform_calc([]{return5*foobar_x()+3;});//toFutureperform_calc([]{return5*foobar_y()-9;});//toPast}图表B:templateintperform_calc(CalcFuncT&&calcfunc){precalc();intconstcalc=

c++ - 使用 lambda 作为异步回调

我有一个程序,我无法在其中使用标准的std::async和线程机制。相反,我必须像这样编写程序:voidprocessor(intargument,std::functioncallback){intblub=0;std::shared_ptrobjptr=getObject();//Functioniscalledlater.//Alltheinternalreferencesareboundhere!autofunc=[=,&blub](){//!Thiswillfailsinceblubisaccessedbyreference!blub*=2;//Sinceobjptrisco

c++ - 具有非静态 lambda 成员的类不能使用默认模板参数?

这个小测试程序:#include//template//structc{std::functionf=[](inti){returni+i;};};intmain(){};Clang-3.2编译正常,但是从GCC4.7.1和4.8我得到了奇怪的错误:t.cc:6:31:error:defaultargumentfortemplateparameterforclassenclosing‘struct__lambda0’functionf=[](inti){returni+i;};^这是没有人知道的那些晦涩难懂的C++规则异常之一,还是GCC错误?编辑看起来像一个错误。我已经提交了bugr

c++ - 使用 boost::lambda::bind 有什么问题?

我正在尝试使用boost::lambda::bind()定义一个谓词,我将其传递给Boost.Range中的find_if算法。具体来说,我想搜索结构vector以找到特定成员具有指定值的第一个条目。我的例子如下:#include#include#includeusingnamespacestd;usingnamespaceboost;usingnamespaceboost::lambda;structfoo{strings;intx;};intmain(){//createlistandaddacoupleentriesvectorfooList;foof1={"abc",1};fo

c++ - 在 lambda 表达式中使用外部函数

是否可以在lambda表达式中调用外部函数,如果不能,是否有另一种方法可以使用transform和外部函数来实现?inthalf(intx){returnx/2;}intmain(){std::vectortest(5);std::transform(test.begin(),test.end(),test.begin(),[](){returnhalf(4);});return0;} 最佳答案 是的,itisdefinitelypossible.事实上,您的代码的唯一问题是您的lambda应该接受int。通过该修复,您的代码com

c++ - lambda 捕获的生命周期

给定以下程序:#include#includeusingnamespacestd;intmain(){std::shared_ptri(newint(42));cout编译器什么时候决定捕获哪些对象?shared_ptri从不在lambda表达式中使用。所以在一个正常的函数中,我会假设优化器会删除这个nop语句。但如果它被删除,编译器可能会认为i不需要被捕获。因此对于gcc,此程序将始终生成1,2作为输出。但这有标准保证吗? 最佳答案 如果我们转到lambdafunction上的cppreference页面他们有以下解释:[=]ca

c++ - 警告从 lambda 返回捕获的引用

我尝试使用lambda有条件地将引用绑定(bind)到两个变量之一:intfoo,bar;int&choice=[&]()->int&{if(true/*somecondition*/){returnfoo;}else{returnbar;}}();这会在clang3.4中产生警告:stack_stuffing.cpp:5:20:warning:referencetostackmemoryassociatedwithlocalvariable'foo'returned[-Wreturn-stack-address]returnfoo;^~~stack_stuffing.cpp:7:20

35 | 并发安全字典sync.Map (下)

我们在上一篇文章中谈到了,由于并发安全字典提供的方法涉及的键和值的类型都是interface{},所以我们在调用这些方法的时候,往往还需要对键和值的实际类型进行检查。这里大致有两个方案。我们上一篇文章中提到了第一种方案,在编码时就完全确定键和值的类型,然后利用Go语言的编译器帮我们做检查。这样做很方便,不是吗?不过,虽然方便,但是却让这样的字典类型缺少了一些灵活性。如果我们还需要一个键类型为uint32并发安全字典的话,那就不得不再如法炮制地写一遍代码了。因此,在需求多样化之后,工作量反而更大,甚至会产生很多雷同的代码。知识扩展问题1:怎样保证并发安全字典中的键和值的类型正确性?(方案二)那么

c++ - __sync_val_compare_and_swap 与 __sync_bool_compare_and_swap

我一直在思考这两个函数的返回值。__sync_bool_compare_and_swap函数的返回值似乎有明显的好处,即我可以用它来判断交换操作是否发生。但是,我看不到__sync_val_compare_and_swap的返回值的良好用途。首先,让我们有一个函数签名供引用(来自GCC文档减去varargs):type__sync_val_compare_and_swap(type*ptr,typeoldvaltypenewval);我看到的问题是__sync_val_compare_and_swap的返回值是*ptr的旧值。准确地说,这是在设置了适当的内存屏障后,此函数的实现所看到的