运算符重载为成员函数还是友元函数的问题

运算符重载为友元函数

class Complex
{
    double real,imag;
    public:
        Complex(double r,double i):real(r),imag(i) { };
        Complex operator+ (double r);
};
Complex Complex::operator+(double r)
{
    return Complex(real + r,imag);
}

可以解释Complex c; c = c + 5,相当于c=c.operator+(5)但是不能解释c = 5 + c,所以将运算符重载为普通函数,此时参数个数就是原生运算符的目数,而不是目数减一,但不能访问对象的私有成员,所以要在类中将函数声明为友元函数。

class Complex
{
    double real,imag;
    public:
        Complex(double r,double i):real(r),imag(i) { };
        Complex operator+ (double r);
        friend Complex operator+ (double r,const Complex & c);
};
Complex Complex::operator+(double r,const Complex & c)
{
    return Complex(c.real + r,c.imag);
}

成员运算符重载函数和友元运算符重载函数的区别

#include <iostream> 
using namespace std;
class Point { 
	private: 
		int x; 
		int y; 
	public: 
		Point() { };
// 在此处补充你的代码
    // istream& operator >>(istream& is)
    // {
    //     is>>this->x >>this-> y;
    //     return is;
    // }
    // ostream& operator <<(ostream& os)
    // {
    //     cout<<this->x<<","<<this->y;
    //     return os;
    // }
    friend istream & operator>>(istream & is, Point & p){
        is >> p.x >>p.y;
        return is;
    }
    friend ostream & operator<<(ostream & os, const Point & p ){
        os << p.x << "," << p.y;
        return os;
    }

}; 
int main() 
{ 
 	Point p;
 	while(cin>>p) {
 		cout<<p<<endl;
	 }
     //目的是 输入1 2 输出1,2
	return 0;
}

上例中成员运算符重载函数是错误的
(1)对于单目运算符,通常重载为成员函数,较为简单.
(2)对于双目运算符,重载为成员函数还是全局函数再声明为友元函数的关键区别是,重载为成员函数时候,参数表中只有一个参数是显式的,另一个参数由this指针传递,并且规定左操作数是由this指针传递,这就带来了一个问题,即左右操作数被规定好了.例如要输出一个对象p,若再类中重载<<,只能是p<<cout,显然不合理,所以双目运算符通常是重载为友元函数,没有了操作数左右的限制.特殊地,对于运算符” =,(),[],->”只能作为成员函数。


类型转换运算符的重载

operator double(){...} 不写返回值
利用类型转换函数的重载,在这个对象所属的类中定义一个类型转换函数,返回一个数,cout这个对象就可以输出这个数(自动类型转换)

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值