一个自增与自减的源码

看了STL源码剖析,自己写的:

#include <iostream>

using namespace std;
//template<class T>
class Int
{
    friend ostream& operator<<(ostream& os,const Int& i);
public:
    Int(int i):m_i(i)
    {

    }
    Int& operator++()
    {
        ++(this->m_i);
        return *this;
    }
    Int& operator--()
    {
        --(this->m_i);
        return *this;
    }
    const Int operator++(int)
    {
        Int temp=*this;
        ++(*this);
        return temp;
    }
    const Int operator--(int)
    {
        Int temp=*this;
        --(*this);
        return temp;
    }
    int& operator*() const
    {
        return (int&)m_i;
    }
private:
    int m_i;
};
ostream& operator<<(ostream& os,const Int& i)
{
    os<<'['<<i.m_i<<']';
    return os;
}
int main()
{
    Int I(5);
    cout<<I++;
    cout<<++I;
    cout<<I--;
    cout<<--I;
    cout<<*I;
    return 0;

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值