草庐IT

add_rvalue_reference

全部标签

c++ - 对 boost::timer::auto_cpu_timer 的 undefined reference

我尝试使用g++4.4在Debian的远程服务器上使用boost库编译小型.cpp文件。为此,我使用Netbeans。我的家用机器在Windows7上。解决了一些链接下一个代码的问题后#include#include#includeintmain(){boost::timer::auto_cpu_timerac;//line5return0;//line6}产生2个错误:第5行:对boost::timer::auto_cpu_timer::auto_cpu_timer(short)'的undefinedreference第6行:对boost::timer::auto_cpu_timer

c++ - add_lvalue_reference_t<T> 和 T& 之间的区别

假设您有一个模板参数T.有什么区别add_cv_t和constvolatileTadd_const_t和constTadd_volatile_t和volatileTadd_lvalue_reference_t和T&add_rvalue_reference_t和T&&add_pointer_t和T*?我为什么要使用add_rvalue_reference_t而不是T&&例如。什么时候选择哪个有什么规则吗? 最佳答案 add_cv_tandconstvolatileTadd_const_tandconstTadd_volatile_ta

c++ - 右值引用 : Why aren't rvalues implicitly moved?

在关于C++右值引用(http://www.artima.com/cppsource/rvalue.html)的Artima文章中有这样的话:这就是为什么在向下传递到基类时必须说move(x)而不是只说x的原因。这是移动语义的一个关键安全特性,旨在防止从某个命名变量意外移动两次。我想不出这样的双招可以执行的情况。你能举个例子吗?换句话说,如果T&&的所有成员都是右值引用而不仅仅是引用,会出现什么问题? 最佳答案 考虑这个场景:voidfoo(std::stringx){}voidbar(std::stringy){}voidtest

c++ - "undefined reference"到从静态方法访问的模板类的静态成员

我有一个静态类方法需要访问一个指针MyTypePointer,因此必须将其声明为静态。因为它是一个模板类,所以我必须将方法放在头文件中,但我不能在头文件中定义MyTypePointer。因此,由于未声明MyTypePointer,我得到了“undefinedReference”错误。我怎样才能使这项工作/声明MyTypePointer。myclass.htemplateclassPathfindingClass{typedefstd::vector*>MyType;staticMyType*MyTypePointer;};templatevoidMyClass::MyMethod(in

c++ - Vector Add的STL算法

假设我有两个vector小号:vectorfoo{1,2,3};vectorbar{10,20,30};现在我想在它们上面做一个vector相加,结果是:112233是否有可以处理此问题的STL算法,或者我是否需要使用for循环:for(autoi=0;i奖金问题,如果我想做比添加更复杂的事情,比如foo怎么办?是一个vector和bar仍然是vector.我希望,如果有我可以使用的STL算法,它也能支持lambdas? 最佳答案 可以使用std::transform实现您想做的事情.在你的情况下:std::transform(fo

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

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

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++ - 获取模板类型的基类型(删除 const/reference/等)

是否有返回给定类型的基本类型的类型特征模板。基本类型是指去除了所有值修饰符、const、volatile等的类型。例如,使用假设的特征函数:base::type==intbase::type==intbase::type==int我知道remove_const和remove_reference并且我目前只是结合使用它们。我想知道是否已经存在这样的特征,也许我所指的是否有合适的名称? 最佳答案 我可能会定义一个类型别名,例如:templateusingbase_type=typenamestd::remove_cv::type>::t

c++ - 右值 lambda 的 std::reference_wrapper 如何工作?

在thisarticle它说以下代码是有效的C++11并且适用于GNU的libstdc++:intn;std::vectorv;...std::functionf(std::cref([n](inti){returni%n==0));std::count_if(v.begin(),v.end(),f);问题是我始终相信lambda对象是在调用站点创建的,这将使它成为此代码段中的临时对象,因为它没有存储在任何变量中,而是存储在const中。正在创建对它的引用并将其传递给std::function.如果是这样,lambda对象应该一直被销毁,在f中留下悬空引用。,当std::count_i