重载+=运算符为什么不是void

如题所述

第1个回答  2022-05-05
一般说的函数类型指的是函数声明(定义)时的返回类型,你说的void类型的函数应该是返回类型为void,形如voidfun()。但是请注意:函数的重载是与返回类型没关系的,而是与函数的参数表有关系,同一作用域同名函数但具有不同参数表时形成重载。所以重载+=运算符不是void。

重载+=运算符为什么不是void
一般说的函数类型指的是函数声明(定义)时的返回类型,你说的void类型的函数应该是返回类型为void,形如voidfun()。但是请注意:函数的重载是与返回类型没关系的,而是与函数的参数表有关系,同一作用域同名函数但具有不同参数表时形成重载。所以重载+=运算符不是void。

重载运算符 返回类型
operator=是s的一个成员函数(operator=不能在全局重载),诸如s=W解释为s.operator=(W),故而这个函数可以不需要返回值(返回void)。之所以有返回值,是一个重载operator=的惯用做法,这样做的好处是支持连续赋值,如a=b=c解释为a.operator=(b.operator=(c)),如果没有返回值,则b.operator=(c...

C++运算符重载,+-*\/的重载,返回值为什么是对象而不是对象的引用?而流操...
原因是:+,-,*等返回不了引用,比如+运算符,可以如下重载(为了简单,假设A 只有int x;int y)A operator+(A a,A b) {A sum; sum.x=a.x+b.x; sum.y=a.y+b.y; return sum; } 分析不能用引用的原因: 函数传入了两个参数a,b,并且+只能传入两个参数(c++不允许自己创...

c++重载单元运算符的函数为什么没有返回类型
重载运算当然可以自己定义返回类型,左值也好右值也好,返回void也好,都是可以的。不过内置类型是前置++返回左值,后置++返回右值的。如果你不希望自己定义的类给用户造成使用上的“迷惑”最好还是使用与内置数据类型相同的返回类型。

java += 运算符不能对除了整数类型之外的类型进行运算?
但是对于其他类型的变量,+= 运算符的行为可能会有所不同。对于除了整数类型之外的类型,+= 运算符的操作行为取决于该类型是否实现了相应的运算符重载。例如,对于字符串类型 String,+= 运算符会进行字符串的拼接操作:javaCopy codeString str = "Hello";str += " World"; \/\/ 等同于 str = ...

为什么会报错,重载加法运算符写的有什么错误么(大概意思是模仿栈一样...
重载加法运算符的这个代码不规范,报错原因集中在图中的加法运算符重载和输出运算符重载函数的定义部分,如下:①+操作数同类型的加法运算符的重载函数,不是友元函数,且其中的左操作数是在形参中无需定义的this指针。形参里只定义右操作数“Stack &s2”,再把含“s1”的语句中的访问成员操作“s1.”...

C++重载=,+=等时候为什么要用返回引用
以ostream为例,重载函数处理的参数是调用调重载运算符的左操作数,比如 cout << a << b;\/\/ int a,b;为什么要返回引用,我说你仔细想一下就明白了,你的函数会修改你操作的流,而流是全局的,不是临时变量,是系统托管的。如果不返回引用,后面对流的操作就是无效的了,因为你返回的只是某时...

c#中重载赋值操作符 我没办法重载+=和= 总是报错 上网查 说这两个...
首先,对于赋值的=是没法重载的,你需要去深入理解下“赋值”。其次,对于+=,它实际是=...+...的简写形式,虽然=不能重载,但+是可以重载的,官方的说法是:“不能直接重载 += 运算符,但用户定义的类型可重载 + 运算符”,也就是说你重载了+就自动可以使用+=了 参考资料:http:\/\/msdn.mic...

在C++中运算符重载的时候究竟什么时候应该加引用,什么时候不应该加引...
如果返回值会被赋值,就必须返回引用,例如=重载\\x0d\\x0a如果返回值是一个局部变量,就一定不能返回引用,例如+重载\\x0d\\x0a如果为了提高效率,参数可以使用引用,\\x0d\\x0a而[]的实际参数经常是一个常量,常量你是无法引用,所以不能用引用作为[]的参数。

c++运算符重载
提示给的很清楚呀。'operator +' must have at least one formal parameter of class type 说重载的+运算符必须有一个参数是类类型。而你的两个参数都是一个指向二维数组的指针,这显然是错误的。而且我显然不能够看明白你重载这个运算符想要完成什么任务。

相似回答
大家正在搜