结果说明
[root@VM_174_171_CentOS unixtime]# g++ -g -o unixtime_simplify unixtime_simplify.cpp
[root@VM_174_171_centos unixtime]# ./unixtime_simplify
Today zero time ==> 1445097600
Week begin time ==> 1444579200
Week end time ==> 1445183999
Is in same day ==> (currtime|one_hour_after = 1), (currtime|one_day_after = 0)
Is in same week ==> (currtime|one_week_after = 0), (one_day_after|one_week_after = 1)
[root@VM_174_171_centos unixtime]# date
Sun Oct 18 13:17:37 CST 2015
[root@VM_174_171_centos unixtime]# date -d @1445097600
Sun Oct 18 00:00:00 CST 2015
[root@VM_174_171_centos unixtime]# date -d @1444579200
Mon Oct 12 00:00:00 CST 2015
[root@VM_174_171_centos unixtime]# date -d @1445183999
Sun Oct 18 23:59:59 CST 2015
在一些活动、任务逻辑中,常常会需要一个类似自然日内统计的数值,过了一天则数值清零。
对于这种需求,我们通常是以 [数值,更新时间] 来表示,在访问时刻进行时间比较,超过时效则清零。以按自然日清零规则来举例,即是在GetValue(), AddValue()时,判断数值的上次更新时间t_upd, 如果IsInSameDay(t_upd, t_now)则当前数值依然有效,否则清零数值后再进行相关操作。每次修改数值时都将t_upd更新成当前时刻。
对于不同时区,公式的区别仅仅在于T1的取值,公式的形式和使用并不需要变化。
一种方式是将T1定义成宏,在国际化时对不同时区的版本,使用不同的T1数值。
另一种方式是将T1定义成全局变量,并在server启动时使用系统的localtime()函数,将T1按当地时区进行合适的初始化取值。
由于每年的天数、每个月的天数不是固定不变的,所以本文的计算思路不适用于每月几号这样的时间点的判断,基于以往的经验,特定月份特定日期的功能需求并不是很普遍,对于这些功能还是使用localtime()函数来的方便一些。
2015职称计算机考试书PowerPoint2007中 .. 定价:¥45 优惠价:¥42 更多书籍 | |
2015年全国职称计算机考试教材(2007模 .. 定价:¥225 优惠价:¥213 更多书籍 |