运算符的重载

#include <iostream>
using namespace std;
class num
{
public:
    num(){n = 1;}
    ~num(){}
    int get()const{return n;}
    void set(int i){n = i;}
    void operator++(){++n;}
private:
    int n;
};
int main()
{
    num i;
    cout << "i:" << i.get() << endl;
    ++i;//注意这里仅仅是对i变量进行操作让i成员改变了,但是它是没有返回值的,
    //++i实际上是调用了operator函数,但是operator函数是void类型,所以不能把++i赋给另一个对象
    cout << "i:" << i.get() << endl;
}

 我们知道,不能把++i赋给另一个新建的对象,因为++i调用的是operator函数,这个函数的返回值是void类型的,但是我们把operator的类型改为num类型的并返回一个对象的时候,就能把++i赋给另一个对象了

#include <iostream>
using namespace std;
class num
{
public:
    num(){n = 1;}
    ~num(){}
    int get()const{return n;}
    void set(int i){n = i;}
    num operator++(){++n; num t; t.set(n); return t;}
    //这样返回一个对象的时候需要另外创建一个对象,仍然不太好,我们可以定义一个带参数的构造函数,比如num(int i){n = i;} ,然后在这个函数里return num(n)即可
private: int n; }; int main() { num i; cout << "i:" << i.get() << endl; ++i; cout << "i:" << i.get() << endl; num j = ++i; cout << "i:" << i.get() << endl; cout << "j:" << j.get() << endl; return 0; }

 还可以优化代码减少构造函数和复制构造函数的调用,节省时间

#include <iostream>
using namespace std;
class A
{
public:
    void set(int n){i = n;}
    A(){cout << "构造" << endl;}
    A(A&s){i = s.i; cout << "复制" << endl;}
    ~A(){cout << "析构" << endl;}

    int get(){return i;}
    void add() {i++;}
    A& operator++(){++i;return *this;}
private:
    int i;
};
int main()
{
    A a;
    a.set(5);
    cout << a.get() << endl;
    a.add();
    cout << a.get() << endl;
    A &n = ++a;
    cout << n.get() << endl;
    return 0;
}

 

posted on 2015-10-15 18:59  张明明_1  阅读(178)  评论(0编辑  收藏  举报

导航