当前位置: 首页 > news >正文

日期类的实现

文章目录

  • 1. 日期类的具体实现
    • 1.查询当前月份的天数
    • 2. 构造函数的实现(注意)
    • 3.d1==d2
    • 4. d1!=d2
    • 5. d1<d2
    • 6. d1<=d2
    • 7. d1>d2
    • 8. d1>=d2
    • 9. 日期+=天数
    • 10.日期+天数
    • 11.日期-=天数
    • 12. 日期-天数
    • 13. ++d和 d++
    • 14. --d 和 d--
    • 15.日期=日期 返回天数
  • 2. 函数的声明——date.h
  • 3. 函数的定义——date.cpp
  • 4.函数调用——main.cpp

由于拆分了函数的声明和定义,所以在函数前面要加上date类,找到函数

1. 日期类的具体实现

1.查询当前月份的天数

int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
  • 设置一个数组,下标对应月份,并把2月闰年的情况单拉出来

2. 构造函数的实现(注意)

date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) )  ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}
}
  • 一定要注意日期传过来是否合法存在

3.d1==d2

bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
  • 判断 年 月 日依次是否相等

4. d1!=d2

bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}

如果我们再次自己写就会有很多情况考虑,所以直接复用 d1==d2的取反

5. d1<d2

bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}

年小的为小,
年相等,月小为小
年 月相等,天小为小
其他情况都为false

6. d1<=d2

bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}

d1<=d2是由 d1==d2 和d1<d2 组成,分别复用两者即可实现

7. d1>d2

bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}

d1>d2的逻辑取反是 d1<=d2 ,由于d1<d2我们已经实现过了,只需要加上d1!=d2即可

8. d1>=d2

bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反 
}

复用d1<d2的逻辑取反即可实现 d1>=d2

9. 日期+=天数

date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}

当day为负时,+= - 等价于-= ,所以调用-=的复用即可(-=实现在后面)
同样由于+=是对于本身操作,除了作用域还存在,所以使用引用返回

10.日期+天数

date date::operator+(int day)
{//注释的为第一种方法//由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{//	getday -= getmonthday(ret._year, ret._month);//	ret._month++;//	if (ret._month == 13)//	{//		ret._year++;//		ret._month = 1;//	}//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;//方法二date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}

这里用了两种方法实现,但是可以发现第一种过于繁琐,只需复用上述+=,返回临时变量tmp即可
同样由于临时变量出了作用域就不存在了,所以使用传值返回

11.日期-=天数

date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this;}_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}

这里不太好想,如果当前日期月份的天数_day大于day,则直接return,若小于则会使_day为负进入循环,同时向上一个月借天数直到 _day<=0
若day为负,-=-等价于+= ,直接复用+=即可

12. 日期-天数

date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}

复用上面的-=即可,返回临时变量ret

13. ++d和 d++

date& date::operator++()//++d
{*this += 1;//复用+=return *this;
}
  • 前置++是正常调用operator++,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator++(int)//d++
{date ret = *this;*this += 1;//复用+=return ret;
}

后置++因为同样是operator++,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回

14. --d 和 d–

date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}
  • 前置- -是正常调用operator- -,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}

后置- -因为同样是operator- -,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回

15.日期=日期 返回天数


date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d)//复用<{max = d;min = *this;}int n = 0;while (min != max)//复用!={n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}

主要使用max和min两个临时变量,使min._day不断++,最终使max==min 结束返回计数n值

2. 函数的声明——date.h

#include<iostream>
using namespace std;
class date
{
public://函数声明int getmonthday(int year, int month);//查询当前月份的天数date(int year=1, int month=1, int day=1);//构造void print();//输出bool operator==(const date& d);//d1==d2bool operator!=(const date& d);//d1!=d2bool operator<(const date& d);//d1<d2bool operator<=(const date& d);//d1<=d2bool operator>(const date& d);//d1>d2bool operator>=(const date& d);//d1>=d2date operator+(int day);//日期+天数date& operator+=(int day);//日期+=天数date operator-(int day);//日期-天数date& operator-=(int day);//日期-=天数date& operator++();//++d//int 参数仅是为了占位,构成函数重载 区分前置date operator++(int);//d++date& operator--();   //--ddate operator--(int);//d--int  operator-( date& d);//日期-日期 返回天数
private:int _year;int _month;int _day;
};

3. 函数的定义——date.cpp

#include"date.h"
//函数实现
int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) )  ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}}
void date::print()
{cout << _year << "-" << _month << "-" << _day << endl;
}
bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}
bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}
bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}
bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}
bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反 
}date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}
date date::operator+(int day)
{由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{//	getday -= getmonthday(ret._year, ret._month);//	ret._month++;//	if (ret._month == 13)//	{//		ret._year++;//		ret._month = 1;//	}//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this;	}_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}
date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}
date& date::operator++()//++d
{*this += 1;return *this;
}
date date::operator++(int)//d++
{date ret = *this;*this += 1;return ret;
}date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d){max = d;min = *this;}int n = 0;while (min != max){n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}

4.函数调用——main.cpp

#include"date.h"
int main()
{date d1(2023, 2, 9);date d2(2023, 2, 1);cout << (d1==d2) << endl;cout << (d1 < d2) << endl;cout << (d1 - d2) << endl;return 0;
}

相关文章:

日期类的实现

文章目录1. 日期类的具体实现1.查询当前月份的天数2. 构造函数的实现(注意)3.d1d24. d1!d25. d1<d26. d1<d27. d1>d28. d1>d29. 日期天数10.日期天数11.日期-天数12. 日期-天数13. d和 d14. --d 和 d--15.日期日期 返回天数2. 函数的声明——date.h3. 函数的定义—…...

2022年这5款熟悉的软件退出了历史舞台

在过去的一年里&#xff0c;有很多新产品发布&#xff0c;当然也有很多产品与我们就此别过。这些产品曾陪伴我们的生活&#xff0c;给我们带来欢乐&#xff0c;帮助我们成长。所以本文将盘点一下在2022年和我们告别的产品。1.微软IE浏览器IE浏览器1995年8月16日正式上线&#x…...

用Nginx打包部署vue3项目及404和500解决

打包vue3 npm run build安装Nginx 这里安装步骤比较繁琐&#xff0c;现在服务器比较便宜&#xff0c;如果想用Nginx&#xff0c;可以去菜鸟教程https://www.runoob.com/linux/nginx-install-setup.html 配置安装一下找到安装路径下的 conf 文件夹 下 nginx.conf文件&#xff0…...

Java面试——多线程并发篇

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…...

维基百科数据抽取

1. 数据路径 https://dumps.wikimedia.org/enwiki/latest/ ----英文 https://dumps.wikimedia.org/zhwiki/latest/ ----中文 https://dumps.wikimedia.org/enwiki/latest/enwiki-latest-pages-articles.xml.bz2 --下载最新的 https://dumps.wikimedia.org/wikidatawiki/2023…...

2020年因果推断综述《A Survey on Causal Inference》

最近阅读了TKDD2020年的《A Survey on Causal Inference》&#xff0c;传送门&#xff0c;自己对文章按照顺序做了整理&#xff0c;同时对优秀的内容进行融合&#xff0c;如有不当之处&#xff0c;请多多指教。 文章对因果推理方法进行了全面的回顾&#xff0c;根据传统因果框…...

嵌入式linux系统测试程序编写

文章目录 网络CPU load监测性能设定开源测试工具iozone —— 文件系统测试工具iperf —— 网络性能测试工具LMbench —— 系统性能评测LTP —— linux功能/性能压力测试memtester —— 内存测试,坏位检测stressapptest —— 内存流量压力测试stream —— 内存性能测试fio ——…...

力扣SQL刷题5

目录597. 好友申请 I&#xff1a;总体通过率602. 好友申请 II &#xff1a;谁有最多的好友603. 连续空余座位1045. 买下所有产品的客户597. 好友申请 I&#xff1a;总体通过率 官方讲的题目太繁琐了&#xff0c;大概就是&#xff08;表2中列1列2不全相同的行数&#xff09;/&a…...

动态规划详解(完结篇)——如何抽象出动态规划算法?以及解题思路

今天直接开始讲解FIRST&#xff1a;如何抽象出动态规划算法&#xff1f;这个问题&#xff0c;困扰了无数代OIER&#xff0c;包括本蒟蒻在比赛的时候&#xff0c;看一道题&#xff0c;怎么想到他是什么算法的呢&#xff1f;这就需要抽象能力而不同的算法&#xff0c;往往有着不同…...

C语言一维数组篇【下】——每日刷题经验分享

一维数组篇——每日刷题经验分享~&#x1f60e;前言&#x1f64c;有序序列插入一个整数 &#x1f60a;序列中删除指定数字 &#x1f60a;序列中整数去重小乐乐查找数字筛选法求素数总结撒花&#x1f49e;&#x1f60e;博客昵称&#xff1a;博客小梦~ &#x1f60a;最喜欢的座右…...

VHDL语言基础-组合逻辑电路-其它组合逻辑模块

目录 多路选择器&#xff1a; 逻辑功能&#xff1a; 常用的类型&#xff1a; 4选1多路选择器的实现&#xff1a; 求补器&#xff1a; 求补器的实现&#xff1a; 三态门&#xff1a; 三态门的应用实例&#xff1a; 三态门的实现&#xff1a; 缓冲器&#xff1a; 什么是…...

初识Vue

文章目录1. 前言2. Vue 的特点3. 安装 Vue4. HelloWord1. 前言 vue是什么 &#xff1f; 引用 &#xff1a; vue.js 文档   Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是&#xff0c;Vue 被设计为可以自底向上逐层…...

TOUGH系列软件建模实践方法及在地下水、CO2地质封存、水文地球化学、地热等多相多组分系统多过程耦合

查看原文>>> https://mp.weixin.qq.com/s?__bizMzAxNzcxMzc5MQ&mid2247578057&idx7&sn75f8d2c1c6edb28af76a8db4bb773de3&chksm9be2aed9ac9527cf0081082cdcf781e6c37f9f3ba383332ed1116abcbee0f05c0593187e964d&token2070450548&langzh_CN#r…...

Codeforces Round #699 (Div. 2)

E. 题意:n本书,每本书有颜色a[i],一次操作可以将其中一本书放在末尾,求满足:相同颜色的书都是相邻的 的最小操作次数. 显然最多只需要n次,考虑能节省多少次.倒着考虑,记f[i]为i~n最多能节约的次数.先预处理出每种颜色的出现的位置范围l[i],r[i]. 1.不节约这本书f[i] f[i 1]…...

MySQL存储过程的传参和流程控制

目录 一.存储过程传参—in 演示 二.存储过程传参—out 演示 三.存储过程传参—inout 演示 四.流程控制—判断 格式 演示 五.流程控制—case 语法 演示 六.流程控制—循环 循环—while 循环—repeat 循环—loop 一.存储过程传参—in in表示传入的参数&#xff0c;可以传…...

MySQl学习(从入门到精通11)

MySQl学习&#xff08;从入门到精通11&#xff09;第 14 章_视图1. 常见的数据库对象2. 视图概述2. 1 为什么使用视图&#xff1f;2. 2 视图的理解3. 创建视图3. 1 创建单表视图3. 2 创建多表联合视图3. 3 基于视图创建视图4. 查看视图5. 更新视图的数据5. 1 一般情况5. 2 不可…...

关于ThreadLocal

弱引用 1.1 java中的各种引用和测试: https://blog.csdn.net/thewindkee/article/details/102723838 1.2 treadlocal中的弱引用测试: https://blog.csdn.net/thewindkee/article/details/103726942 (这篇很重要) 内存泄露: https://zhuanlan.zhihu.com/p/523628871 综合考虑 …...

【C++】类和对象(中)

文章目录1. 类的6个默认成员函数2. 构造函数概念特性3. 析构函数概念特性4. 拷贝构造函数概念特征5. 运算符重载5.1 前置和后置重载5.2 赋值运算符重载6. 日期类的实现7. const成员8. 取地址及const取地址操作符重载1. 类的6个默认成员函数 如果一个类中什么成员都没有&#x…...

js下载文件

url为文件的src地址 url必须符合同源策略或者url的接口地址允许跨域&#xff0c;否则浏览器会报跨域错误 axios.get(data.url ,{ responseType: ‘blob’, }) .then( response>{ let blob new Blob([response.data]); let url window.URL.createObjectURL(blob); // 创建 …...

ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟

ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟 📍相关篇《ESP8266 + STC15基于AT指令通过TCP通讯协议获取时间》 📌ESP8266 AT固件基于安信可AT固件,相关刷AT固件可以参考《NodeMCU-刷写AT固件》 🔖STC15 单片机采用的是:STC15F2K60S2 晶振频率采用内部:22.11…...

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …...

XCTF-web-easyupload

试了试php&#xff0c;php7&#xff0c;pht&#xff0c;phtml等&#xff0c;都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接&#xff0c;得到flag...

视频字幕质量评估的大规模细粒度基准

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 摘要 视频字幕在文本到视频生成任务中起着至关重要的作用&#xff0c;因为它们的质量直接影响所生成视频的语义连贯性和视觉保真度。尽管大型视觉-语言模型&#xff08;VLMs&#xff09;在字幕生成方面…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作

一、上下文切换 即使单核CPU也可以进行多线程执行代码&#xff0c;CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短&#xff0c;所以CPU会不断地切换线程执行&#xff0c;从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...

MySQL账号权限管理指南:安全创建账户与精细授权技巧

在MySQL数据库管理中&#xff0c;合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号&#xff1f; 最小权限原则&#xf…...

JAVA后端开发——多租户

数据隔离是多租户系统中的核心概念&#xff0c;确保一个租户&#xff08;在这个系统中可能是一个公司或一个独立的客户&#xff09;的数据对其他租户是不可见的。在 RuoYi 框架&#xff08;您当前项目所使用的基础框架&#xff09;中&#xff0c;这通常是通过在数据表中增加一个…...

C++.OpenGL (14/64)多光源(Multiple Lights)

多光源(Multiple Lights) 多光源渲染技术概览 #mermaid-svg-3L5e5gGn76TNh7Lq {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-3L5e5gGn76TNh7Lq .error-icon{fill:#552222;}#mermaid-svg-3L5e5gGn76TNh7Lq .erro…...

Linux系统部署KES

1、安装准备 1.版本说明V008R006C009B0014 V008&#xff1a;是version产品的大版本。 R006&#xff1a;是release产品特性版本。 C009&#xff1a;是通用版 B0014&#xff1a;是build开发过程中的构建版本2.硬件要求 #安全版和企业版 内存&#xff1a;1GB 以上 硬盘&#xf…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制

目录 节点的功能承载层&#xff08;GATT/Adv&#xff09;局限性&#xff1a; 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能&#xff0c;如 Configuration …...