原子的代码:
u8 RTC_Get_Week(u16 year,u8 month,u8 day)
{
u16 temp2;
u8 yearH,yearL;
yearH=year/100; yearL=year%100;
// 如果为21世纪,年份数加100
if (yearH>19)yearL+=100;
// 所过闰年数只算1900年之后的
temp2=yearL+yearL/4;
temp2=temp2%7;
temp2=temp2+day+table_week[month-1];
if (yearL%4==0&&month<3)temp2--;
return(temp2%7);
}
先来看一下月修正数据表 table_week[12]={0,3,3,6,1,4,6,2,5,0,3,5};假设1月1日是星期一,那么2月1日是星期四,(4-1=3),故是3,3月1日是星期四,(4-1=3),4月1日是星期日(7-1=6);这样依次类推。前提是这一年是平年。
yearH=year/100; yearL=year%100;
// 如果为21世纪,年份数加100
if (yearH>19)yearL+=100; 这几行算出本年和1900年之差
temp2=yearL+yearL/4; year/4是闰年的年数,平年一年365天,365%7=1;temp2算出自1900年以来积累的多出来的天数;
temp2=temp2+day+table_week[month-1];//算出当天比1900年1月1日多出来的天数,并不是实际多出来的,table_week[month-1]已经除过7了
if (yearL%4==0&&month<3)temp2--;如果是润年1月,2月的话要减去一,因为yearL/4已把当年多出来的一天计算进去了,多出来的一天是在三月份以后才能加的
temp%7就是算出来的日期了。
啊~~~~~~~~原子的代码这么精简,看了老半天才懂
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
---------------------------------
之所以那么做月基数,就是为了简化方程,泰勒定理就是从一个原点开始,然后只算天数累积,之后的各种月基数延伸方法都是为了简化这个方程。
---------------------------------
如果写的是calendar而非clock,这段代码还是需要的。
如果只是年月日星期简单显示,这段代码确实不是必须的;直接=((timecount/86400)+4)%7会更简单些。
yearH=year/100; yearL=year%100;
// 如果为21世纪,年份数加100
if (yearH>19)yearL+=100;
搞不懂为什么这么绕?
看了半天就是算和1900差多少年吧,为什么不用 year-1900得到呢?
减去2001行不行?必须减1900吗?
同意,今早看不懂原子哥的代码,用这个公式算了下,有效
一周热门 更多>