我的一天从 2013 年 11 月 2 日 00:00 开始,到 23:59 结束,因为新的一天是 2013 年 11 月 3 日 00:00 - 数学 23:59 - 00:00 我得到 23:59 ,这意味着我每天损失 1 分钟。我是否需要每次添加 +1 分钟才能获得 24:00 作为结果。如果是这样,我该如何处理这个问题:由于新的一天,23:59 开始和 23:59 结束?
有时在 1 分钟内点击几次给我
Opt1 clock start 12:30 end 12:30 = 0 min
Opt2 clock start 12:30 end 12:30 = 0 min
Opt1 clock start 12:30 end 12:30 = 0 min
Opt2 clock start 12:30 end 12:31 = 1 min
这么久没关系,但我不知道“时钟开始 23:59 结束 23:59”是实际完成的工作还是错误。如果这是一个错误,那么 0 分钟就可以了,但如果它不是一个错误,那么我会失去 1 分钟。
我在一个小计时器上工作,但我找不到该问题的解决方案。
也许我需要用户的额外确认?
但是当它到达 23:59:59 时它会自动切换到新的一天,所以我得到 23:59 作为前一天的最后一点,新的一天从 00:00 开始。
如何把握好时机?晚上 11:59 和上午 12:00 也是如此——同样的一天在晚上 11:59 结束,因为新的一天从上午 12:00 开始,对吧?
那么如何补偿那 1 分钟呢?
更新:
时间格式为 SimpleDateFormat foutputFormat = new SimpleDateFormat("dd/MM/yyyy HH:mm");
解析到日期,然后做简单的数学运算
mint+= (finishd[i].getTime()/60000) - (startd[i].getTime() / 60000);
////System.out.println(mint);
int h=(int)mint/60;
int m=(int)mint-(h*60);
////System.out.println("Min: " +mint);
String totaltime = h + "h"+":" + m+"min";
////System.out.println("H: " + h + "Min: " + m);
问题是当我有:开始 01/03/2004 00:00 和结束 01/03/2004 23:59 。第二天从 02/03/2004 00:00 开始。我得到 23 小时:59 分钟的工作时间,而不是 24 小时 - 一整天我都使用 SQL 数据库来保存和读取数据。数据格式“dd/MM/yyyy HH:mm”;
快到了 :D 对我来说最后一个问题是我需要做这样的数学运算:
pause 10:20 - 10:40 = 20 min OK
working 10:40 - 12:42 = 2h:2min OK
pause 12:42 - 12:57 = 15 min OK
working 12:57 - 12:57 = 0 OK
pause 12:57 - 12:57 = 0 OK
working 12:57 - 16:00 = 3h:3min OK
Total work 5h:5min / pause 35min OK
最后是23:59的问题:
working 22:00 - 23:59 = 1h:59m missing 24! 1min lost
NEW DAY working 00:00 - 04:30 = 4h:30min OK
那么如何修复最后一个 23:59 可以是 23:59 - 23:59 pause = 0 min OK
或者它可以是
day1 23:59 - day2 00:20 = 21min ?
但 SQL 只能将信息存储为 00-59min 00-23h
然后如果我需要那天的总工作和总停顿:我可以总结那天的所有记录,当我暂停 + 工作时,我将得到 23:59h