在STM32的RTC程序中,关于函数void GregorianDay(struct rtc_time * tm)的问题 15
voidGregorianDay(structrtc_time*tm){intleapsToDate;intlastYear;intday;intMonthOffset[...
void GregorianDay(struct rtc_time * tm)
{
int leapsToDate;
int lastYear;
int day;
int MonthOffset[] = { 0,31,59,90,120,151,181,212,243,273,304,334 };
lastYear=tm->tm_year-1;
/*
* Number of leap corrections to apply up to end of last year
*/
leapsToDate = lastYear/4 - lastYear/100 + lastYear/400;
/*
* This year is a leap year if it is divisible by 4 except when it is
* divisible by 100 unless it is divisible by 400
*
* e.g. 1904 was a leap year, 1900 was not, 1996 is, and 2000 will be
*/
if((tm->tm_year%4==0) &&
((tm->tm_year%100!=0) || (tm->tm_year%400==0)) &&
(tm->tm_mon>2)) {
/*
* We are past Feb. 29 in a leap year
*/
day=1;
} else {
day=0;
}
day += lastYear*365 + leapsToDate + MonthOffset[tm->tm_mon-1] + tm->tm_mday;
tm->tm_wday=day%7;
}
这个函数中。计数元年是从0000年开始的吗,如果是从1970开始,怎么没减去1970呢 展开
{
int leapsToDate;
int lastYear;
int day;
int MonthOffset[] = { 0,31,59,90,120,151,181,212,243,273,304,334 };
lastYear=tm->tm_year-1;
/*
* Number of leap corrections to apply up to end of last year
*/
leapsToDate = lastYear/4 - lastYear/100 + lastYear/400;
/*
* This year is a leap year if it is divisible by 4 except when it is
* divisible by 100 unless it is divisible by 400
*
* e.g. 1904 was a leap year, 1900 was not, 1996 is, and 2000 will be
*/
if((tm->tm_year%4==0) &&
((tm->tm_year%100!=0) || (tm->tm_year%400==0)) &&
(tm->tm_mon>2)) {
/*
* We are past Feb. 29 in a leap year
*/
day=1;
} else {
day=0;
}
day += lastYear*365 + leapsToDate + MonthOffset[tm->tm_mon-1] + tm->tm_mday;
tm->tm_wday=day%7;
}
这个函数中。计数元年是从0000年开始的吗,如果是从1970开始,怎么没减去1970呢 展开
展开全部
我不知道你要问的和这个函数的关系
这个函数只不过是对闰年与否的日期及星期的处理计算,并没有涉及到1970或者之前,也就是1970之前之后都是可以算的通用程序
而像现在的很多软件如数据库等都会把时间表示成一个长整形数字,这个数字就是从1970年1月1日开始累加的时间。
这个函数只不过是对闰年与否的日期及星期的处理计算,并没有涉及到1970或者之前,也就是1970之前之后都是可以算的通用程序
而像现在的很多软件如数据库等都会把时间表示成一个长整形数字,这个数字就是从1970年1月1日开始累加的时间。
追问
tm->tm_wday=day%7;
那这句话应该是算星期的
另外定义了一个星期的数组u8 const *WEEK_STR[] = {"日", "一", "二", "三", "四", "五", "六"};看了下函数,这个结果余几就对应的数组中的星期几,那这个算星期的其日期也是以1970年一月一日的星期数为起点吗
追答
我阅读了你的程序,你的程序中这个函数和1970没有任何关系
你的时间结构体中存的是 年月日
这个函数主要功能是计算给定年月日当天是星期几
计算方法是:
首先计算这一年的二月有多少天,即判断闰年
因为数组给的每月对应的天数是没有闰年的,所以如果是闰年需要加一天,也就是day=1
然后计算当天距离0000年过了多少天得到星期
从公元元年一月一日开始到现在,每一天都是连续的,而每个星期有7天,也是连续的,也就是说日期和星期是一对一的,没有断档现象。我的基本思想是计算出当前天是从公元元年一月一日开始的第几天,再利用星期的周期性来计算公元任何一天是星期几。
当前1月1日开始到当前天的天数e
t=x+365*(y-1)+((y-1)/4-(y-1)/100+(y-1)/400)+e 再用t除以7,余几即为星期几(余0为星期日)。
你可以搜星期的求法来深入了解这个
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
意法半导体(中国)投资有限公司
2023-06-12 广告
2023-06-12 广告
STM32F103R8T6是ST旗下的一款常用的增强型系列微控制器,是一款基于ARM Cortex-M内核的微控制器。STM32F103R8T6主要面向消费类电子产品、工业控制、医疗仪器、汽车电子等领域,可用于开发各种类型的应用。STM32...
点击进入详情页
本回答由意法半导体(中国)投资有限公司提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询