#include<iostream>
using namespace std;
class Date
{
public:
    Date(int year = 1900, int month = 1, int day = 1)   //构造
    :_year(year)
    , _month(month)
    , _day(day)
    {
        if (!isInvalidDate(_year, _month, _day))
        {
            _year = 1900;
            _month = 1;
            _day = 1;
        }
    }
    
    Date operator+(int count)
    {
        Date tmp(*this);
        tmp._day += count;
        ToCorrect(tmp);
        return tmp;
    }
    Date operator-(int count)
    {
        Date tmp(*this);
        tmp._day -= count;
        ToCorrect(tmp);
        return tmp;
    }
    
    Date& operator++()   //前置++
    {
        (*this)++;
        return *this;
    }
    Date operator++(int)    //后置++
    {
        Date tmp(*this);
        (*this)+=1;
        return tmp;
    }
    Date& operator--()
    {
        (*this)--;
        return *this;
    }
    Date operator--(int)
    {
        Date tmp(*this);
        (*this)--;
        return tmp;
    }
    int operator-(const Date &d)
    {
        int flag = 1;
        Date max = *this;
        Date min = d;
        if (*this<d)
        {
            max = d;
            min = *this;
            flag = -1;
        }
        int count=0;
        while (min != max)
        {
            ++min;
            count++;
        }
        return count*flag;
    }
    Date& operator+=(int day)
    {
        *this = *this + day;
        return *this;
    }
    bool operator!=(const Date &d)
    {
        return !(*this == d);
    }
    bool operator<(const Date &d)
    {
        return !((*this>d)||(*this==d));
    }
    bool operator>=(const Date &d)
    {
        return !(*this<d);
    }
    bool operator>(const Date &d)
    {
        return (_year > d._year
            || (_year == d._year && _month > d._month)
            || (_year == d._year && _month == d._month && _day > d._day));
    }
    bool operator==(const Date &d)
    {
        return ((_year == d._year) && (_month == d._month) && (_day == d._day));
    }
    
public:    
    bool IsLeapYear(int year)
    {
        if(year % 400 || (year % 4 && year % 100))
            return true;
        return false;
    }
    int YearsOfMonth(int year, int month)
    {
        int day;
        int days[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
        day = days[month];
        if (month == 2)
            day += IsLeapYear(year);
        return day;
    }
    
    Date ToCorrect(Date &d)
    {
        if (d._day>YearsOfMonth(d._year, d._month))
        {
            while (d._day > YearsOfMonth(d._year, d._month))
            {
                 d._day -= YearsOfMonth(d._year,d._month);

if (d._month == 12)
                {
                    d._year++;
                    d._month = 1;
                }
                else
                {
                    ++d._month;
                }
            }
        }
        else
        {
            while (d._day <= 0)
            {
                if (d._month == 1)
                {
                    d._year--;
                    d._month = 12;
                }
                else
                {
                    --d._month;
                }
                d._day += YearsOfMonth(d._year, d._month);
            }
        }
        return d;
    }

bool isInvalidDate(int year, int month, int day)
    {
        if ((year < 1) || (month<0 || month>12) || (day<0 || day>YearsOfMonth(year,month)))
            return false;
        return true;
    }
    void Display()
    {
        cout << _year << "-" << _month << "-" << _day << endl;
    }
    friend istream& operator>>(istream& is, Date &d);
    friend ostream& operator<<(ostream& os, const Date &d);
private:
    int _year;
    int _month;
    int _day;
};
istream& operator>>(istream& is, Date& d)
{
    cout << "请输入一个日期" << endl;
    is >> d._year >> d._month >> d._day;
    return is;
}

ostream& operator<<(ostream& os, const Date &d)
{
    cout << d._year << "-" <<d. _month << "-" << d._day << endl;
    return os;
}
int main()
{
    /*Date d1(2016,8,18);
    //d1.Display();

//d1 = d1++;
    cout << d1 << endl;*/

//Date d1(2015, 12, 3);
    //(d1++).Display();  //d1.operator++(&d1, 0);
    //(++d1).Display(); //d1.operator++(&d1);

Date d1(2015, 12, 3);
    Date d2(2015, 11, 1);
    cout << (d1 - d2) << endl;

//Date d1(2015, 12, 3);
    //Date ret = d1 + 40; //operator+
    //ret.Display();

/*Date d1(2015, 12, 3);
    Date ret = d1 + 40;
    d1 = ret;
    ret = d1 - 40;
    ret.Display();*/
    
    /*Date ret;
    Date d2(2015, 1, 1);
    ret = d2 - 1;
    ret.Display();*/
    return 0;
}

C++实现日期类(Date类)的更多相关文章

  1. 日期操作类--Date类

    Date-API ava.util包提供了Date类来封装当前的日期和时间.Date类提供两个构造函数来实例化Date对象.第一个构造函数使用当前日期和时间来初始化对象. Date( ) 第二个构造函 ...

  2. Java关于时间日期的Date类和Calendar类概述

    1.      System.currentTimeMillis()方法 可以获取当前时间距离1970年01月01日00时00分00秒的秒数,如果程序运行在北京时区,则获取的数据是当前时间距离1970 ...

  3. java日期时间Date类

    java.util包提供了Date类来封装当前的日期和时间. Date类提供两个构造函数来实例化Date对象. 第一个构造函数使用当前日期和时间来初始化对象. Date( ) 第二个构造函数接收一个参 ...

  4. java常用类————Date类

    Date类在Java.util包中. 一.功能介绍:创建Date对象,获取时间,格式化输出的时间. 二.对象创建:1.使用Date类无参数的构造方法创建的对象可以获取本地时间.例如: Date now ...

  5. Java学习关于时间操作的应用类--Date类、Calendar类及其子类

    Date类 Date类封装了当期时间和日期.与Java1.0定义的原始版的Date类相比,Date类发生了本质的变化.在Java1.1发布时,原始版Date类定义的许多功能被移进Calendar类和D ...

  6. Java api 入门教程 之 JAVA的Date类与Calendar类

    在JDK1.0中,Date类是唯一的一个代表时间的类,但是由于Date类不便于实现国际化,所以从JDK1.1版本开始,推荐使用Calendar类进行时间和日期处理. 一.这里简单介绍一下Date类的使 ...

  7. JAVA的Date类与Calendar类【转】

    Date类 在JDK1.0中,Date类是唯一的一个代表时间的类,但是由于Date类不便于实现国际化,所以从JDK1.1版本开始,推荐使用Calendar类进行时间和日期处理.这里简单介绍一下Date ...

  8. Java的Date类与Calendar类

    一:Date类 在JDK1.0中,Date类是唯一的一个代表时间的类,但是由于Date类不便于实现国际化,所以从JDK1.1版本开始,推荐使用Calendar类进行时间和日期处理.这里简单介绍一下Da ...

  9. Date 类 02

    Date类 在JDK1.0中,Date类是唯一的一个代表时间的类,但是由于Date类不便于实现国际化,所以从JDK1.1版本开始,推荐使用Calendar类进行时间和日期处理.这里简单介绍一下Date ...

  10. Java知多少(77)日期和时间类

    Java 的日期和时间类位于 java.util 包中.利用日期时间类提供的方法,可以获取当前的日期和时间,创建日期和时间参数,计算和比较时间. Date 类 Date 类是 Java 中的日期时间类 ...

随机推荐

  1. BZOJ2961: 共点圆

    好久没发了 CDQ分治,具体做法见XHR的论文… /************************************************************** Problem: 29 ...

  2. 后缀树系列一:概念以及实现原理( the Ukkonen algorithm)

    首先说明一下后缀树系列一共会有三篇文章,本文先介绍基本概念以及如何线性时间内构件后缀树,第二篇文章会详细介绍怎么实现后缀树(包含实现代码),第三篇会着重谈一谈后缀树的应用. 本文分为三个部分, 首先介 ...

  3. Codeigniter整合Tank Auth权限类库的教程

    Codeigniter整合Tank Auth权限类库的教程一开始找了很多CodeIgniter的类库,觉得都不怎么样,后来干脆自己通过CI的钩子系统写了权限管理.但是还是不怎么满意,后来有人推荐tan ...

  4. [转载] Linux poll机制

    原地址:http://hongwazi.blog.163.com/blog/#m=0&t=3&c=poll poll的是一种查询的方式,英文解释 :民意调查 函数原型:int poll ...

  5. Android核心分析 之二方法论探讨之概念空间篇

    方法论探讨之概念空间篇 我们潜意识就不想用计算机的方式来思考问题,我们有自己的思维描述方式,越是接近我们思维描述方式,我们越容易接受和使用.各种计算机语言,建模工具,不外乎就是建立一个更接近人的思维方 ...

  6. iOS App 唤醒另一个App

    网上也有讲这块的,感觉讲得都不是很好.而且有一些细节根本没有讲清楚.这里重写整理一下相关知识点. 主要内容 URL Scheme 是什么? 项目中关键的配置 注意事项 URL Scheme 是什么? ...

  7. iOS sqlite3数据库解析

    看来从版本3.3.1基本上已经支持线程句柄的传递功能.具体限制我标记了一下.(6) Is SQLite threadsafe?SQLite is threadsafe. We make this co ...

  8. http://biancheng.dnbcw.info/java/138631.html

    http://biancheng.dnbcw.info/java/138631.html

  9. Largest Rectangle in Histogram-最大长方形

    题目描述: 给定n个非负整数height[n],分别代表直方图条的高,每个条的宽设为1,求直方图中面积最大的矩形的面积 题目来源: http://oj.leetcode.com/problems/la ...

  10. Android 怎样把光标放在EditText中文本的末尾处?

    EditText et = (EditText)findViewById(R.id.inbox); et.setSelection(et.getText().length());