草庐IT

0x00000bc4

全部标签

c++ - 如何在不使用 C++0x 的情况下创建 lambda 函数来匹配 boost::function 参数?

如何使用boost或STL创建lambda函数以匹配中第三段代码中F期望的boost::function参数主?#include#includevoidF(inta,boost::functionf){std::cout我不能使用C++0x并且想避免创建几个单独的函数。如果有帮助,我可以使用boost::function以外的东西,我的首要任务是简洁地创建lambda。 最佳答案 #include//STL#include//Boost.Lambda#include//Boost.Pheonix#include//Boost.Phe

c++ - C++0x 中 std::make_tuple 的问题

使用VisualStudio10编译以下程序时,出现了很多编译错误:#include"stdafx.h"#include#include#include#includeint_tmain(intargc,_TCHAR*argv[]){typedefstd::tuplekey_t;typedefstd::mapmap_t;map_tthe_map;autok=std::make_tuple("one","two");the_map[k]="thevalue";autoq=std::make_tuple("one","two");autoi=the_map.find(q);std::cou

c++ - 直接从 C++0x lambda 调用方返回

我刚刚重写了以下从当前函数返回的C89代码://makesuretheinodeisn'topen{size_ti;for(i=0;ihtab);++i){structHandleconst*consthandle=&g_cpfs->htab[i];if(handle_valid(handle)){if(handle->ino==(*inode)->ino){log_info("Inode"INO_FMT"isstillopen,delayingremoval.",(*inode)->ino);returntrue;}}}}使用这个C++0xSTL/lambda混合体:std::for

c++ - 在 C++0x 中未调用移动构造函数

请在下面找到我的代码,我曾经调用移动构造函数(代码灵感来自其他站点)并让我知道它有什么问题,我使用的是GCC4.5.3#include#includeclassInt_Smart_Pointer{int*m_p;public:Int_Smart_Pointer(){std::coutptr_vec;ptr_vec.push_back(getMove_Constructor());ptr_vec.push_back(getMove_Constructor());std::cout输出是ExplicitConstructor:10CopyConstructor:ExplicitConstr

c++ - 在 MacOSX Lion 上编译 gcc 4.6.1 C++0x 线程代码时出错

编译以下代码时:#include#includeusingnamespacestd;voidhello(){cout使用:$g++-4.6.1-std=c++0x-pthreadthreading.cpp我收到以下错误:threading.cc:Infunction‘intmain()’:threading.cc:13:2:error:‘thread’wasnotdeclaredinthisscopethreading.cc:13:9:error:expected‘;’before‘t’threading.cc:14:2:error:‘t’wasnotdeclaredinthissco

c# - c++0x 概念和 c# 约束有什么区别?

C++0x引入了概念,让您基本上可以定义一种类型。Itspecifiesthepropertiesrequiredofatype.C#允许您使用“where”子句指定泛型的约束。它们之间有语义上的区别吗?谢谢。 最佳答案 要记住的一件事是C++模板和C#泛型并不完全相同。看这个answer有关这些差异的更多详细信息。从您链接到解释C++0x概念的页面来看,听起来您的想法是在C++中您希望能够指定模板类型实现某些属性。在C#中,约束更进一步,并强制泛型类型“属于”该约束。例如,以下C#代码:publicGenericListwhere

c++ - 使用 C++0x 的 unordered_map

我正在使用unordered_map其中包括:#include程序编译如下:g++Test.cc-std=gnu++0x-otest我在使用unordered_map吗?TR1或C++0x的。还是两者相同? 最佳答案 我相信gcc将他们的TR1header放在中,所以你应该得到C++11版本。但它们非常相似。 关于c++-使用C++0x的unordered_map,我们在StackOverflow上找到一个类似的问题: https://stackoverflo

c++ - std0x 和非 std0x 之间的 Rcpp 不一致

我发现在使用和不使用-std=c++0x编译的Rcpp之间存在奇怪的不一致。考虑表达式Functiondata_frame("data.frame");GenericVectora;a.push_back("17");returndata_frame(a,_["stringsAsFactors"]=0);(编者注:在Rcpp中对DataFrame的强制转换实际上向下转换为R函数,但不允许用户设置该标志。)在“旧”C++(未设置-std=c++0x)中,此代码有效。在现代C++中(w/-std=c++0x设置),这失败了,说“不能将类“pairlist”强制转换为data.frame”。

c++ - 在 C++0x 标准中会有 unordered_map,这与 boost unordered_map 相比如何?

哪个更有效率?有什么好的基准吗? 最佳答案 C++11的std::unordered_map规范类似于基于tr1::unordered_map的boost::unordered_map。话虽这么说,还是有一些细微的差别。在C++11中添加右值引用会导致添加可能对性能有用的emplace和emplace_hint函数。C++11现已得到广泛实现,因此您应该能够开箱即用地使用std::unordered_map。C++14不会对其进行重大更改,C++17将(可能)添加insert_or_assign和try_emplace成员函数。

c++ - 在 C++ 0x 中 boost lambda::_1

intmain(){std::vectorv;v.push_back(1);v.push_back(3);v.push_back(2);std::for_each(v.begin(),v.end(),std::cout可以不使用Boost将此代码转换为C++吗?我知道C++0xlambda表达式语法,但没有尝试在这种情况下使用占位符。 最佳答案 在这种情况下不需要占位符,因为lambda捕获参数:std::for_each(v.begin(),v.end(),[](intx){std::cout