u32 mktimev(struct rtc_time *tm)
{
if (0 >= (int) (tm->tm_mon -= 2)) { /* 1..12 -> 11,12,1..10 */
tm->tm_mon += 12; /* Puts Feb last since it has leap day */
tm->tm_year -= 1;
}
return (((
(u32) (tm->tm_year/4 - tm->tm_year/100 + tm->tm_year/400 + 367*tm->tm_mon/12 + tm->tm_mday) +
tm->tm_year*365 - 719499
)*24 + tm->tm_hour /* now have hours */
)*60 + tm->tm_min /* now have minutes */
)*60 + tm->tm_sec; /* finally seconds */
}
在写文案时候突然不好解释719499与367,所以有此篇文章
367:367*tm->tm_mon/12此算式可以通过取整数方式算出大小月,把个月带进去展开来看
| 转换后2月在年末 | 转换前月份 | 计算的天数 | 月差 |
| 1 | 3 | 30 | 30 |
| 2 | 4 | 61 | 31 |
| 3 | 5 | 91 | 30 |
| 4 | 6 | 122 | 31 |
| 5 | 7 | 152 | 30 |
| 6 | 8 | 183 | 31 |
| 7 | 9 | 214 | 31 |
| 8 | 10 | 244 | 30 |
| 9 | 11 | 275 | 31 |
| 10 | 12 | 305 | 30 |
| 11 | 1 | 336 | 31 |
| 12 | 2 | 367 | 31 |
日期有特色,实际上的数字未过完,比如2024年8月18日,其实2024年未过完2月份和8月份计算闰年情况不一样,所以有了2月挪到年末计算方式。8月也未过完,不应该算,只要算满7月份即可,所以上表可以看作当月和上月月初实际过的天数,符合大小月设定,但是注意多算了30天,后面再表。
719499:由于是从1970年1月1日算的,但是经历的秒数应该为:
1970X365+1970/4-1970/100+1970/400=719527
但是367的时候已经发现多算了30,所以得减去30
还有因为本身月份是减去了两个月则应该加上31一月份和28的二月份(闰年另一个公式补了)
然后当天不应该算所以再减去1,则:
-719527-30+31+28-1=-719499
解答完毕。
3412

被折叠的 条评论
为什么被折叠?



