Handling TimeZone change with Date class in JAVA

后端 未结 3 424
长情又很酷
长情又很酷 2021-01-22 07:24

I am trying to print the current system date and time as below,

public class PrintDate {

    public void getDate(){
        while(true){
            System.out.         


        
相关标签:
3条回答
  • 2021-01-22 07:38

    The answer by neuhaus is correct.

    If you meant you changed the time zone of your host operating system while running that code, know that the Java Virtual Machine (JVM) has its own current default time zone.

    Usually that default is picked up from that of the host OS. If so in your case, that must mean your Java implementation is detecting the host time zone only at launch and not checking for later changes in the host OS‘ time zone.

    The time zone of your JVM can also be set as a configuration parameter upon launch. In that case I should think the JVM would purposely ignore the host OS’ time zone changes.

    Any Java code in any thread of any app within that JVM can change the JVM’s current default time zone at any moment during runtime. Again, I should think the JVM would purposely ignore the host OS’ time zone changes.

    The class doc for java.util.TimeZone.getDefault() outlines steps taking in determining the current default time zone.

    If the cached default TimeZone is available, its clone is returned. Otherwise, the method takes the following steps to determine the default time zone.

    • Use the user.timezone property value as the default time zone ID if it's available.

    • Detect the platform time zone ID. The source of the platform time zone and ID mapping may vary with implementation.

    • Use GMT as the last resort if the given or detected time zone ID is unknown.

    The default TimeZone created from the ID is cached, and its clone is returned. The user.timezone property value is set to the ID upon return.

    In my reading of that, it says the JVM is not going to detect any changes to the host OS setting. Once launched, and once a default has been determined, it is stored in that user.timezone property (and a value in cache) until changed with a call to setDefault.

    java.time

    You are using the old java.util.Date class which has been supplanted by the java.time framework in Java 8.

    Use the java.time.ZonedDateTime class and specify the desired/expected time zone.

    ZoneId zoneId = ZoneId.of( " America/Montreal" );
    ZonedDateTime zdt = ZonedDateTime.now( ZoneId );
    

    You should almost never depend on the JVM’s current default time zone ( nor the current default Locale).

    0 讨论(0)
  • 2021-01-22 07:42

    The time zone is part of the environment of the process. Changing the time zone globally for your system only affects new processes.

    See also How to set time zone of a java.util.Date?:

    Be aware that java.util.Date objects do not contain any timezone information by themselves - you cannot set the timezone on a Date object. The only thing that a Date object contains is a number of milliseconds since the "epoch" - 1 January 1970, 00:00:00 UTC.

    As ZZ Coder shows, you set the timezone on the DateFormat object, to tell it in which timezone you want to display the date and time.

    0 讨论(0)
  • 2021-01-22 07:56
    import java.util.Date;
    
    public class DateDemo {
       public static void main(String args[]) {
     //Instantiate a Date object
           Date date = new Date();
     //display time and date using toString()
           System.out.println(date.toString());
       }
    }
    
    0 讨论(0)
提交回复
热议问题