草庐IT

Function_Reference

全部标签

c++ - 使用参数包将 lambda 转换为 std::function

关于将lambda转换为std::function的SO有几个问题s,但我还没有看到一个使用参数包作为参数列表的。这在我的g++(7.1.1-4)版本上似乎已损坏,可能只是不受支持。那么这是合法的c++17(按照标准)吗?如果不是,为什么?#includetemplatevoidFunctor(std::functionf){}intmain(intargc,char*argv[]){autox=[](inta,intb){returna*b;};Functor(x);return0;}上面的代码无法编译,因为它没有通过类型推导。显然明确输入x作为std::function而不是使用a

C++ 对象 : When should I use pointer or reference

我可以使用一个对象作为指向它的指针,或者它的引用。我知道不同之处在于必须手动删除指针,而引用会一直保留到超出范围为止。我应该什么时候使用它们?实际区别是什么?这两个问题都没有回答我的疑惑:Pointervs.ReferenceC++differencebetweenreference,objectsandpointers 最佳答案 引用基本上是一个有限制的指针(必须在创建时绑定(bind),不能反弹/为空)。如果您的代码使用这些限制是有意义的,那么使用引用而不是指针允许编译器警告您意外违反它们。它很像const限定符:没有它语言也可

c++ - 在 std::function 中存储不可复制但可移动的对象

假设我有一个不可复制但可移动的仿函数s,我如何将它存储在std::function中?即,如何编译以下代码?(使用gcc4.6)#include#includestructS{S()=default;S(Sconst&)=delete;S&operator=(Sconst&)=delete;S(S&&){}voidoperator()(){}};std::functionfunc;voidmake_func(){Ss;func=std::bind(std::move(s));//Thiswon'tcompile}intmain(){make_func();}

C++ 错误 : object of abstract class type is not allowed: pure virtual function has no overrider

继承有问题。我不知道我做错了什么。FigureGeometry.h#ifndefFIGUREGEOMETRY#defineFIGUREGEOMETRYstaticconstfloatPI=3.14159f;classFigureGeometry{public:virtualfloatgetArea()const=0;virtualfloatgetPerimeter()const=0;};#endifCircle.h#ifndefCIRCLE#defineCIRCLE#include"FigureGeometry.h"classCircle:publicFigureGeometry{fl

c++ - Visual Studio 2010 和 std::function

我有这个代码:#include#includestructA{intoperator()(inti)const{std::coutf=std::tr1::ref(a);std::cout目的是通过reference_wrapper传递仿函数对象,以避免无用的复制构造函数调用。我期望以下输出:F:67它可以与GCC>=4.4.0、VisualStudio2008以及通过将std::tr1命名空间替换为boost的boost一起正常工作。它仅不适用于新的VisualStudio2010ExpressBeta2和ReleaseCandidate。这个新的C++特性在vs2010中有问题吗?或

c++ - 对 `mysql_init' 的 undefined reference

我正在尝试在我的新服务器上编译我的程序,但它目前对我不起作用。错误日志是:rasmus@web01:~/c++$maketestg++`mysql_config--cflags--libs`main.cpplogger.cppcpulogger.cpp-otest/tmp/ccPaMZUy.o:Infunction`CPULogger':/home/rasmus/c++/cpulogger.cpp:7:undefinedreferenceto`mysql_init'/home/rasmus/c++/cpulogger.cpp:8:undefinedreferenceto`mysql_r

c++ - 对运算符<< 的 undefined reference

我有一个常规类(不是模板)和一个私有(private)friend操作符它的声明是:std::ostream&operator在cpp文件中它的定义是:std::ostream&operator它正在被编译然后链接到使用它的主函数,但是当我使用它时我得到一个undefinedreference...然而,当我将定义添加到主cpp文件的顶部并删除友元声明时,它工作正常...这是我在主要功能中使用它的方式std::coutgetPosition()不多也不少...这是链接器错误/home/luke/Desktop/pathfinder/parse_world.cpp:34:undefine

c++ - 无法使用统一初始化复制 std::vector<std::function<void ()>>。这个对吗?

以下代码无法在GCC4.7.2或Clang3.2中编译:#include#includeintmain(){std::vector>a;std::vector>b{a};}问题是编译器将尝试使用initializer_list创建b,而显然它应该只是调用复制构造函数。然而,这似乎是期望的行为,因为标准规定initializer_list构造函数应该优先。此代码适用于其他std::vector,但对于std::function,编译器无法知道您是否需要initializer_list构造函数或其他构造函数。似乎没有办法绕过它,如果是这种情况,那么您永远不能在模板代码中使用统一初始化。这将

c++ - std::function 与原始函数指针和 void* this 相比的性能?

库代码:classResource{public:typedefvoid(*func_sig)(int,char,double,void*);//RegistrationregisterCallback(void*app_obj,func_sigfunc){_app_obj=app_obj;_func=func;}//Callingwhenthetimecomesvoidcall_app_code(){_func(231,'a',432.4234,app_obj);}//Otherusefulmethodsprivate:void*app_obj;func_sig_func;//Oth

c++ - 绑定(bind) lambda 的速度(通过 std::function)与仿函数结构的 operator()

autolam=[](inta,intb,intc){returna在版本一中,我们std::vector>lamvals;//getparametersandforeachlamvals.emplace_back(std::bind(lam,a,std::placeholders::_1,b));替代方案是std::vectorlamvals;//getparametersandforeachlamvals.emplace_back(functor{a,b});在这两种情况下我们都有一个简单的迭代returnstd::any_of(lamvals.cbegin(),lamvals.c