草庐IT

ref-parameters

全部标签

c++ - std::string& 与 boost::string_ref

如果我在std::string&上使用boost::string_ref还重要吗?我的意思是,在处理字符串时,使用boost::string_ref真的比std版本更有效吗?我真的不明白这里提供的解释:http://www.boost.org/doc/libs/1_61_0/libs/utility/doc/html/string_ref.html.真正让我感到困惑的是std::string也是一个仅指向分配内存的句柄类,并且自c++11以来,具有移动语义的复制操作在上面的文章中提到不会发生。那么,哪个更有效? 最佳答案 strin

c++ - std::ref 和 swap 函数似乎不能很好地协同工作

templatevoidmyswap(Ta,Tb){Ttemp=a;a=b;b=temp;}intmain(){intm(20),n(30);myswap(ref(m),ref(n));//misstill20andnisstill30}为什么m和n的值没有互换?将包装在std::ref中的值传递给INCREMENT函数会导致原始变量(调用INCREMENT函数的堆栈帧中的变量)中的值发生变化。或者,std::ref的使用是否受到限制? 最佳答案 std::ref(及其关联的std::reference_wrapper)是为标准库中

C++ 风格约定 : Parameter Names within Class Declaration

我是一个相当新的C++程序员,我想听听支持和反对在类声明中命名参数的争论。这是一个例子:Student.h#ifndefSTUDENT_H_#defineSTUDENT_H_#includeusingnamespacestd;classStudent{private:stringname;unsignedintage;floatheight,GPA;public:Student(string,unsignedint,float,float);voidsetAge(unsignedint);};#endif/*STUDENT_H_*/对比#ifndefSTUDENT_H_#defineS

C++ 宏 : manipulating a parameter (specific example)

我需要更换GET("any_name")与Stringstr_any_name=getFunction("any_name");困难的部分是如何去掉引号。可能的?有什么想法吗? 最佳答案 怎么样:#defineUNSAFE_GET(X)Stringstr_##X=getFunction(#X);或者,为了防止嵌套宏问题:#defineSTRINGIFY2(x)#x#defineSTRINGIFY(x)STRINGIFY2(x)#definePASTE2(a,b)a##b#definePASTE(a,b)PASTE2(a,b)#def

C++11 operator""with double parameter

考虑:structstr{};stroperator""_X(longdoubled){returnstr();}这在g++4.7.2Wallstd=c++11下编译得很好但现在如果我给双倍:stroperator""_X(doubled){returnstr();}我收到以下错误消息:main.cpp|3|错误:'stroperator""_X(double)'的参数列表无效问题是什么?这与“无法重新定义内置文字后缀的含义”(StroustrupFAQ)有关吗?您能想出解决方法吗? 最佳答案 Whatistheproblem?问题

c++ - 当模板template-parameter的模板参数为pack expansion时,gcc失败,clang成功

templatestructS{templatestructA{};templatestructB{};templateclass>structC{};};S::C::B>s1;S::C::A>s2;//gcc5.1.0fails,clang3.6.0succeedsintmain(){}你可以在这里测试http://melpon.org/wandbox/permlink/hhy70gO9LMjLq9nU哪个是正确的,gcc还是clang? 最佳答案 这个问题在gcc6.0中已经解决 关

c++ - 显式默认/删除的函数可以在 ref 限定符上重载吗?

简介Refqualifiers:一种消除隐含对象的rl-valuness歧义的方法。作为一个简单的例子,以下面的类为例classexample{intmember;public://...int&value()&;//^int&&value()&&;//^^intconst&value()const&;//^};使用此C++11功能(用^标记的语法),允许我们控制将用value()的版本p>左值临时工常量左值实际上ref限定适用于类的*thisDefaulted/Deletedfunctions:将一个特殊成员函数指定为编译器生成(默认)定义或不可访问(删除)。举个例子structty

c++ - 拥有一个 ref 类型的类成员的目的是什么?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭11年前。我有这段代码,但它不是一个实际的例子。例如classAnimal{inti;int&ref;public:Animal():ref(i){}};任何人都可以提供一个现实生活中需要ref作为类(class)成员的例子,以便我更好地理解它吗?

c++ - 为什么 "const Eigen::Matrix<>&"和 "const Ref<Eigen::Matrix<>>"显然不兼容?

这是我的示例代码:(请注意#ifENABLE_MY_COMPILE_ERROR包围的部分)#include#include#defineENABLE_MY_COMPILE_ERROR1voidf1(constEigen::Refa,constEigen::Refb,Eigen::Refc){c=a*b;}intmain(intargc,constchar*argv[]){Eigen::Matrix3dM;Eigen::Vector3dx;Eigen::Vector3dy;M.setRandom();x.setRandom();std::cout这是我在ENABLE_MY_COMPILE

c++ - std::[tr1::]ref 和 boost::ref 之间的混淆

注意:这是GCC4.1.2。我们在专有的嵌入式平台上。我们无法更新到新的编译器。所以C++03+TR1是。我们在某个地方有这样一个函数:templatevoidfoo(constboost::any&x){bar(boost::any_cast(x));}随后在绑定(bind)表达式中使用:std::tr1::bind(&foo,_1);这会产生以下错误:error:callofoverloaded'ref(constboost::any&)'isambiguousnote:candidatesare:std::tr1::reference_wrapperstd::tr1::ref(_