C++结构体的构造函数以及运算符的重载

由于结构体经常用到,所以对结构体的用法做了一下整理

#include<iostream>
using namespace std;
struct node
{
    int x,y;
    static const int BASC=10000;   //定义静态成员变量
    node(int x=0,int y=0):x(x),y(y){}   //构造函数
    //重载输出流
    friend ostream& operator<<(ostream&out,const node &p)
    {
        out<<p.x<<" "<<p.y<<endl;
        return out;
    }
    //重载输入流,不能为const
    friend istream&operator>>(istream&in,node &p)
    {
        in>>p.x>>p.y;
        return in;
    }
    //重载<,成员函数
    bool operator<(const node&p)const
    {
        return x<p.x;
    }
    //重载>友元函数
    friend bool operator>(const node &a,const node &b)
    {
        return a.x>b.x;
    }
    //重载+,调用构造函数
    friend node operator+(const node&a,const node&b)
    {
        return node(a.x+b.x,a.y+b.y);
    }

};
int main()
{
    int x;
    node a(1,2),b(3,4);    //初始化
    cout<<a<<b;
    cout<<(a>b)<<endl<<(a<b)<<endl;
    cout<<a+b;
    cout<<node::BASC<<endl;    //访问结构体的静态成员变量
    while(cin>>a)
    {
        cout<<a;
    }
    return 0;
}

其中值得注意的是对于流的重载,ostream后的&尽量加上

如果写成这样   ostream operator << (ostream& os, Point& pt) 
则:
Point a, b;
cout<<a<<b;
错误,只能写为:
cout<<a;
cout<<b;
原因在于
cout<<a<<b;
相当于:
(cout<<a)<<b;
第一个()中返回cout的临时变量,它可以不可以作为左值。因而错误。
如果写成:  ostream& operator << (ostream& os, Point& pt) 
则:
cout<<a<<b;
正确,因为它等同于
(cout<<a)<<b;
(acout<<a)返回cout的引用,即就是它自己,它可以再次作为左值。因而能够连着写这个输出流



  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值