我想生成日期列表,但发现日期从-25 * 24 * 60 * 60 * 1000开始是错误的
我的本地日期是2016-07-17。我有
2016-07-17 2016-07-16 2016-07-15 ... 2016-06-23 **2016-08-11**
我不知道从哪里来2016-08-11。我按照下面的(xxx和yyy)将25分解为24和-1 ,然后得到正确的日期2016-06-22。
2016-08-11
xxx
yyy
2016-06-22
为什么xxx起作用但yyy不起作用?
Date xxx = new Date(new Date().getTime()-24 * 24 * 60 * 60 * 1000 -1 * 24 * 60 * 60 * 1000); Date yyy = new Date(new Date().getTime()-25 * 24 * 60 * 60 * 1000);
这是我的代码:从i = 25起日期是错误的
for (int i=0; i<240;i++) { Date dt = new Date(new Date().getTime() - i * 24 * 60 * 60 * 1000); Log.e(TAG,Global.sdfDateTime19.format(dt)); }
您超出了的范围int。i * 24 * 60 * 60 * 1000产生一个int(其然后从减去long从getDate)。
int
i * 24 * 60 * 60 * 1000
long
getDate
可以i是24,因为结果是2,073,600,000,小于一个int2,147,483,647 的最大正值。但是当到达时i = 25,您会回绕(如果不限制为int21.6亿,则值太大)。
i
i = 25
只需将其long声明i为long或将24 a设置为乘法即可long:
Date dt = new Date(new Date().getTime() - i * 24L * 60 * 60 * 1000); // ---------------------------------------------^
为什么xxx有效,但yyy不有效?
因为您已将乘法分解为两部分 (为了清楚起见,我在其中添加了一个空格,因为-1否则看起来像是负数,而不是后面跟着的减法运算符1):
-1
1
Date xxx = new Date(new Date().getTime()-24 * 24 * 60 * 60 * 1000 - 1 * 24 * 60 * 60 * 1000); // The first part -----------------------^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^ // The second part ------------------------------------------------/
…而您将其拆分成两个部分的任何一个都不会溢出的范围int。
通常,我不建议以这种方式操作日期,尤其是因为并非所有的日期都恰好有24小时(考虑进入和退出夏令时的日期)。我将使用一个库,该库可以让您在“日常”级别工作,例如Java 8 java.time或JodaTime或类似的东西。
java.time