【发布时间】:2020-03-28 21:38:35
【问题描述】:
我尝试了 const 和通过引用传递的变体,但似乎在每个走廊上都有问题。 此配置给出错误无法将“thingArr&”类型的非常量左值引用绑定到“thingArr”类型的右值 我做错了什么?
#include <iostream>
using namespace std;
template <typename T>
class thingArr
{
public:
thingArr(){for(int i=0;i<4;++i)n[i] = 1;}
thingArr(thingArr& mIn){for(int i=0; i<4; ++i)n[i]=mIn.n[i];}
friend std::ostream& operator << (std::ostream& s, thingArr<T>& m)
{
s<<"\n("<<m.n[0]<<", "<<m.n[1]<<", "<<m.n[2]<<", "<<m.n[3]<<")";
return s;
}
friend thingArr operator * (thingArr inThingArr, T inScalar)
{
thingArr out(inThingArr);
for(int i=0;i<4;++i)out.n[i]*=inScalar;
return thingArr(out);
}
T n[4];
};
main(){
thingArr<float> A;
thingArr<float> B;
B = A * .25;
cout <<"A: "<<A<<endl;
cout <<"B: "<<B<<endl;
}
【问题讨论】:
-
为什么不在 args 中
const thingArr& mIn? -
在第 16 行给出错误“‘thingArr
&’类型的绑定引用到‘const thingArr ’丢弃限定符” -
const thingArr<float>来自哪里?我在您的代码中没有看到它。只需return out。 -
啊!好的,领先。谢谢你。 !这似乎有效:``` class thingArr { public: thingArr(){for(int i=0;i& m) { s
-
为什么不在 args 中
const thingArr<T>& m?
标签: c++ templates operator-overloading friend