- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
以下示例尝试计算时区之间的小时差。
import java.util.*;
import java.text.*;
public class ForPosting
{
public static void main (String[] args)
{
try {
String myDateString = "07-13-2021 11:00:00";
SimpleDateFormat localDateTime = new SimpleDateFormat("MM-dd-yyyy HH:mm:ss");
SimpleDateFormat utcDateTime = new SimpleDateFormat("MM-dd-yyyy HH:mm:ss");
localDateTime.setTimeZone(TimeZone.getTimeZone("EET"));
System.out.println(localDateTime.parse(myDateString));
utcDateTime.setTimeZone(TimeZone.getTimeZone("UTC"));
System.out.println(utcDateTime.parse(myDateString));
float diff = ((localDateTime.parse(myDateString).getTime() - utcDateTime.parse(myDateString).getTime() ) / 3600000);
System.out.println("EET & UTC Time Difference : " + diff);
localDateTime.setTimeZone(TimeZone.getDefault());
System.out.println(localDateTime.parse(myDateString));
utcDateTime.setTimeZone(TimeZone.getTimeZone("UTC"));
System.out.println(utcDateTime.parse(myDateString));
diff = ((localDateTime.parse(myDateString).getTime() - utcDateTime.parse(myDateString).getTime() ) / 3600000);
System.out.println("Default & UTC Time Difference : " + diff);
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
以上代码生成以下输出。
Default & UTC Time Difference : 4.0
已通过检查当前日期确认并确认存在 4 小时差异。
对 EET 和 UTC 进行相同的检查是不同的。
EET & UTC Time Difference : -3.0
输出显示有 3 小时的差异,但下面显示只有 2 小时。
为什么 EET 和 UTC 实际时间显示 2 小时差异而 Java 代码显示 3 小时差异?
最佳答案
EET 是欧洲和北非大约 20 个时区的常用缩写,在标准时间期间,这些时区与 UTC 的偏移量为 +02:00。许多,并非全部都使用夏令时(夏令时)缩写为东欧夏令时的 EEST,因此在 7 个“夏季”月份中偏移 +03:00。所以当请求 EET
时你会得到什么,我不知道。所以不要那样做。使用正确的时区 ID,例如 Europe/Uzhgorod,始终采用 region/city 格式。这样你就知道你得到了什么。
所以回答你的问题:
Why does the EET & UTC actual time show 2 hour difference yet the Javacode shows a 3 hour difference?
因为他们对 EET 的解释不同。这两种解释都是完全有效的,没有一个是权威的。
这对 EET 来说没什么特别的。许多两个、三个、四个和五个字母的时区缩写是常用的。其中很多都是模棱两可的,例如 EET。其中很多不是时区。可能在某些情况下,您可以使用一个与用户进行非正式交流,例如,在用户非常清楚 EET 和 EEST 中的每一个在上下文中的含义的情况下,只是为了区分 EET 和 EEST。您当然不能依赖它们在您的程序中定义时区。
我建议您使用 java.time,这是现代 Java 日期和时间 API,用于您的日期和时间工作。要及时找出某个时区与 UTC 之间的时差:
ZoneId zone = ZoneId.of("Europe/Uzhgorod");
Instant when = Instant.now();
ZoneOffset differenceFromUtc = when.atZone(zone).getOffset();
System.out.format("%s & UTC Time Difference : %s%n", zone, differenceFromUtc);
刚才运行时的输出:
Europe/Uzhgorod & UTC Time Difference : +03:00
Europe/Uzhgorod 现在是夏天,3 小时的时差来自使用夏令时的时区。冬天用速溶试试:
Instant when = Instant.parse("2022-01-01T00:00:00Z");
Europe/Uzhgorod & UTC Time Difference : +02:00
正如我所说,一些东欧时区不使用夏令时。尝试其中之一:
ZoneId zone = ZoneId.of("Europe/Kaliningrad");
Instant when = Instant.now();
Europe/Kaliningrad & UTC Time Difference : +02:00
虽然 UTC
用于定义时区,但规范 ID 是 Etc/UTC
。 Etc 是不属于明确定义的地理区域的时区的伪区域,包括 Etc/UTC
、Etc/GMT
以及仅用于整体的 ID -小时偏移量,如 Etc/GMT-2
(对于偏移量 +02:00,符号是倒置的)。
将除法的结果分配给 float
对您没有帮助。您将 long
值除以 int
值,结果总是被截断为 long
数字。分配给 float
时,您仍然会得到一个整数。如果您想要一个分数作为结果,则需要在 除法之前将至少一个操作数转换为 float
(或 double
)。
还有一个有趣的细节,您的代码测量 EET 11 点和 UTC 11 点之间的小时差。你得到一个结果正是因为这两个时刻之间有 3 个小时。我不太高兴的是您没有在明确定义的时间点衡量差异。相反,在我的代码中,我选择了一个时间点并找出那个时间点的差异。
Oracle tutorial: Date Time解释如何使用 java.time。
关于java - 为什么从两个不同时区减去相同日期时会出现时差?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68367350/
我正在尝试创建一个程序,该程序采用两个军事时间的差异并获取其时差。 示例: **上午到下午** 时间 1:0900 时间 2:1730 时差:8 小时 30 分钟 **下午到上午** 时间 1:120
我正在尝试计算两个时间字段之间的时间差异。由于这些字段只是没有日期的时间,因此我无法使用 timestampdiff,因此我使用 timediff() 或 subtime() 。唯一的问题是,当第二次
我试图简单地计算 5:30:00 - 2:30:00 的时差。显然这应该导致 3:00:00 但是当我在控制台中执行以下代码时 var a = new Date(0,0,0,5,30,0) var b
我试图在 C 中区分两个日期,但我收到这样的输出: future date: 18-11-2013 22:8 current date: 18-11-2013 22:8 这是我的代码: #includ
我正在尝试计算截至上午 00:00 的剩余分钟数。 DELIMITER // CREATE PROCEDURE midnightCountdown() BEGIN SELECT TIME_FORMAT
我正在尝试使用 postgresql 从表(login_history as t1)中检索以分钟为单位的时差。 当我尝试这段代码时 ((date_part('hour', timestamp '201
欢迎!我有问题想问你。我正在 Laravel 5.2 中为自己编写飞行日志。在公式中,我将有起飞时间和到达时间,但我不知道如何在 laravel 中计算时间差并将其自动传递到数据库。因此,最简单的方法
我已经查看了有关此主题的其他问答,但没有找到任何帮助。 我的应用记录比赛结果并保存到文件。 第一次点击它会写入当前时间,当运行者完成后,它会再次记录当前时间。 如何计算这两个时间以获得比赛时间? 这是
我有非常简单的代码来计算两次之间的差异: import java.text.SimpleDateFormat; import java.util.Date; import java.util.Greg
在 Python 中比较 2 次以加快测试一段代码的正确方法是什么?我尝试阅读 API 文档。我不确定我是否理解 timedelta。 到目前为止,我有这个代码: from datetime impo
这个问题非常类似于Best timestamp format for CSV/Excel? : 我正在写一个 CSV 文件。我需要编写至少精确到秒,最好精确到毫秒的时间跨度(又名时差)。 CSV 文件
我试图通过输入时间格式计算12小时内的java时差,当我输入开始时间11:58:10 pm和结束时间12:02时效果很好:15 点。但当我输入 12:00:00 am 和 12:00:00 pm 时,
因此,对于一项作业,我们必须编写一个程序,该程序需要两次军事时间,并显示它们之间的小时和分钟差异,假设第一次是两次时间中较早的一次。我们不允许使用 if 语句,因为它在技术上尚未被学习。这是运行时的示
我必须为分布在全局各地的所有人员制定 24 小时时间表。 例如,某人可以在 10:00 开始工作,并在 19:00 结束工作,因此获得时差非常简单,因为结束时间和开始时间在同一天。但是,如果我有人在
使用 ntp 时间时,(英国)返回的时间总是比实际时间少一小时。例如:现在时间是 13.35 但当我说日期时,它返回 12.35。有什么建议? try: c = ntplib.
我有一个应用程序,它在登录时记录时间,在退出时记录退出时间。 我的表有 IN_TIME 和 OUT_TIME 这些列中的数据示例: IN_TIME = 16:06:46 结束时间 = 16:08:07
我使用 $_POST 将变量从 ajax 表单发布到 php 服务器端我有两个变量,时间和金额。在服务器中,我有一个 MYSQL 数据库,其中包含 _end_time (数据类型:时间)和金额(数据类
我正在尝试计算在这里工作的人的轮类模式,从结束时间减去开始时间在大多数情况下都有效,但如果他们通宵工作则不行。例如,从 10pm 到 6am 工作的人将显示为: 22:00 - 06:00 我希望返回
任何人都可以提供一个 Excel 方程来计算两个 UTC 时间戳之间的差异。 UTC 时间戳的格式为 yyyymmddhhmmssZ(例如 20160127175049Z)。时间戳之间的差异最多为几个
我在大学学习一门名为“智能机器”的类(class)。我们向我们介绍了 3 种强化学习方法,并通过这些方法我们获得了何时使用它们的直觉,我引用: Q-Learning - 当 MDP 无法解决时最好。
我是一名优秀的程序员,十分优秀!