{"id":3883,"date":"2022-08-20T21:54:24","date_gmt":"2022-08-20T16:24:24","guid":{"rendered":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/"},"modified":"2022-08-20T21:54:24","modified_gmt":"2022-08-20T16:24:24","slug":"solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result","status":"publish","type":"post","link":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/","title":{"rendered":"(Solved) Why is subtracting these two times (in 1927) giving a strange result?"},"content":{"rendered":"<p> [ad_1]<br \/>\n<\/p>\n<div id=\"answer-6841479\" class=\"answer js-answer accepted-answer js-accepted-answer\" data-answerid=\"6841479\" data-parentid=\"6841333\" data-score=\"11664\" data-position-on-page=\"1\" data-highest-scored=\"1\" data-question-has-accepted-highest-score=\"1\" itemprop=\"acceptedAnswer\" itemscope itemtype=\"https:\/\/schema.org\/Answer\">\n<div class=\"post-layout\">\n<div class=\"votecell post-layout--left\"><\/div>\n<div class=\"answercell post-layout--right\">\n<div class=\"s-prose js-post-body\" itemprop=\"text\">\n<p>It&#8217;s a time zone change on December 31st in Shanghai.<\/p>\n<p>See <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/www.timeanddate.com\/worldclock\/clockchange.html?n=237&amp;year=1927\">this page<\/a> for details of 1927 in Shanghai. Basically at midnight at the end of 1927, the clocks went back 5 minutes and 52 seconds. So &#8220;1927-12-31 23:54:08&#8221; actually happened twice, and it looks like Java is parsing it as the <em>later<\/em> possible instant for that local date\/time &#8211; hence the difference.<\/p>\n<p>Just another episode in the often weird and wonderful world of time zones.<\/p>\n<p><strong>EDIT:<\/strong> Stop press! History changes&#8230;<\/p>\n<p>The original question would no longer demonstrate quite the same behaviour, if rebuilt with version 2013a of <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/nodatime\/nodatime\/blob\/master\/src\/NodaTime.Demo\/StackOverflowExamples.cs#L68\">TZDB<\/a>. In 2013a, the result would be 358 seconds, with a transition time of 23:54:03 instead of 23:54:08.<\/p>\n<p>I only noticed this because I&#8217;m collecting questions like this in Noda Time, in the form of <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/nodatime\/nodatime\/blob\/master\/src\/NodaTime.Demo\/StackOverflowExamples.cs#L68\">unit tests<\/a>&#8230; The test has now been changed, but it just goes to show &#8211; not even historical data is safe.<\/p>\n<p><strong>EDIT:<\/strong> History has changed again&#8230;<\/p>\n<p>In TZDB 2014f, the time of the change has moved to 1900-12-31, and it&#8217;s now a mere 343 second change (so the time between <code>t<\/code> and <code>t+1<\/code> is 344 seconds, if you see what I mean).<\/p>\n<p><strong>EDIT:<\/strong> To answer a question around a transition at 1900&#8230; it looks like the Java timezone implementation treats <em>all<\/em> time zones as simply being in their standard time for any instant before the start of 1900 UTC:<\/p>\n<pre><code>import java.util.TimeZone;\n\npublic class Test {\n    public static void main(String[] args) throws Exception {\n        long startOf1900Utc = -2208988800000L;\n        for (String id : TimeZone.getAvailableIDs()) {\n            TimeZone zone = TimeZone.getTimeZone(id);\n            if (zone.getRawOffset() != zone.getOffset(startOf1900Utc - 1)) {\n                System.out.println(id);\n            }\n        }\n    }\n}\n<\/code><\/pre>\n<p>The code above produces no output on my Windows machine. So any time zone which has any offset other than its standard one at the start of 1900 will count that as a transition. TZDB itself has some data going back earlier than that, and doesn&#8217;t rely on any idea of a &#8220;fixed&#8221; standard time (which is what <code>getRawOffset<\/code> assumes to be a valid concept) so other libraries needn&#8217;t introduce this artificial transition.<\/p>\n<\/p><\/div>\n<div class=\"mt24\"><\/div>\n<\/div>\n<p>            <span class=\"d-none\" itemprop=\"commentCount\">0<\/span> <\/p><\/div>\n<\/div>\n<p>[ad_2]<\/p>\n<p>solved Why is subtracting these two times (in 1927) giving a strange result? <\/p>\n","protected":false},"excerpt":{"rendered":"<p>[ad_1] It&#8217;s a time zone change on December 31st in Shanghai. See this page for details of 1927 in Shanghai. Basically at midnight at the end of 1927, the clocks went back 5 minutes and 52 seconds. So &#8220;1927-12-31 23:54:08&#8221; actually happened twice, and it looks like Java is parsing it as the later possible &#8230; <a title=\"(Solved) Why is subtracting these two times (in 1927) giving a strange result?\" class=\"read-more\" href=\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\" aria-label=\"More on (Solved) Why is subtracting these two times (in 1927) giving a strange result?\">Read more<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[320],"tags":[433,323,434],"class_list":["post-3883","post","type-post","status-publish","format-standard","hentry","category-solved","tag-date","tag-java","tag-timezone"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.5 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb\" \/>\n<meta property=\"og:description\" content=\"[ad_1] It&#8217;s a time zone change on December 31st in Shanghai. See this page for details of 1927 in Shanghai. Basically at midnight at the end of 1927, the clocks went back 5 minutes and 52 seconds. So &#8220;1927-12-31 23:54:08&#8221; actually happened twice, and it looks like Java is parsing it as the later possible ... Read more\" \/>\n<meta property=\"og:url\" content=\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\" \/>\n<meta property=\"og:site_name\" content=\"JassWeb\" \/>\n<meta property=\"article:published_time\" content=\"2022-08-20T16:24:24+00:00\" \/>\n<meta name=\"author\" content=\"Kirat\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Kirat\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\"},\"author\":{\"name\":\"Kirat\",\"@id\":\"https:\/\/jassweb.com\/solved\/#\/schema\/person\/65c9c7b7958150c0dc8371fa35dd7c31\"},\"headline\":\"(Solved) Why is subtracting these two times (in 1927) giving a strange result?\",\"datePublished\":\"2022-08-20T16:24:24+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\"},\"wordCount\":323,\"publisher\":{\"@id\":\"https:\/\/jassweb.com\/solved\/#organization\"},\"keywords\":[\"date\",\"java\",\"timezone\"],\"articleSection\":[\"Solved\"],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\",\"url\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\",\"name\":\"(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb\",\"isPartOf\":{\"@id\":\"https:\/\/jassweb.com\/solved\/#website\"},\"datePublished\":\"2022-08-20T16:24:24+00:00\",\"breadcrumb\":{\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/jassweb.com\/solved\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"(Solved) Why is subtracting these two times (in 1927) giving a strange result?\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/jassweb.com\/solved\/#website\",\"url\":\"https:\/\/jassweb.com\/solved\/\",\"name\":\"JassWeb\",\"description\":\"Build High-quality Websites\",\"publisher\":{\"@id\":\"https:\/\/jassweb.com\/solved\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/jassweb.com\/solved\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/jassweb.com\/solved\/#organization\",\"name\":\"Jass Web\",\"url\":\"https:\/\/jassweb.com\/solved\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/jassweb.com\/solved\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/jassweb.com\/wp-content\/uploads\/2021\/02\/jass-website-logo-1.png\",\"contentUrl\":\"https:\/\/jassweb.com\/wp-content\/uploads\/2021\/02\/jass-website-logo-1.png\",\"width\":693,\"height\":132,\"caption\":\"Jass Web\"},\"image\":{\"@id\":\"https:\/\/jassweb.com\/solved\/#\/schema\/logo\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\/\/jassweb.com\/solved\/#\/schema\/person\/65c9c7b7958150c0dc8371fa35dd7c31\",\"name\":\"Kirat\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/jassweb.com\/solved\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/jassweb.com\/solved\/wp-content\/litespeed\/avatar\/1261af3c9451399fa1336d28b98ea3bb.jpg?ver=1775798750\",\"contentUrl\":\"https:\/\/jassweb.com\/solved\/wp-content\/litespeed\/avatar\/1261af3c9451399fa1336d28b98ea3bb.jpg?ver=1775798750\",\"caption\":\"Kirat\"},\"sameAs\":[\"http:\/\/jassweb.com\"],\"url\":\"https:\/\/jassweb.com\/solved\/author\/jaspritsinghghumangmail-com\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/","og_locale":"en_US","og_type":"article","og_title":"(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb","og_description":"[ad_1] It&#8217;s a time zone change on December 31st in Shanghai. See this page for details of 1927 in Shanghai. Basically at midnight at the end of 1927, the clocks went back 5 minutes and 52 seconds. So &#8220;1927-12-31 23:54:08&#8221; actually happened twice, and it looks like Java is parsing it as the later possible ... Read more","og_url":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/","og_site_name":"JassWeb","article_published_time":"2022-08-20T16:24:24+00:00","author":"Kirat","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Kirat","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#article","isPartOf":{"@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/"},"author":{"name":"Kirat","@id":"https:\/\/jassweb.com\/solved\/#\/schema\/person\/65c9c7b7958150c0dc8371fa35dd7c31"},"headline":"(Solved) Why is subtracting these two times (in 1927) giving a strange result?","datePublished":"2022-08-20T16:24:24+00:00","mainEntityOfPage":{"@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/"},"wordCount":323,"publisher":{"@id":"https:\/\/jassweb.com\/solved\/#organization"},"keywords":["date","java","timezone"],"articleSection":["Solved"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/","url":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/","name":"(Solved) Why is subtracting these two times (in 1927) giving a strange result? - JassWeb","isPartOf":{"@id":"https:\/\/jassweb.com\/solved\/#website"},"datePublished":"2022-08-20T16:24:24+00:00","breadcrumb":{"@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/jassweb.com\/solved\/solved-why-is-subtracting-these-two-times-in-1927-giving-a-strange-result\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/jassweb.com\/solved\/"},{"@type":"ListItem","position":2,"name":"(Solved) Why is subtracting these two times (in 1927) giving a strange result?"}]},{"@type":"WebSite","@id":"https:\/\/jassweb.com\/solved\/#website","url":"https:\/\/jassweb.com\/solved\/","name":"JassWeb","description":"Build High-quality Websites","publisher":{"@id":"https:\/\/jassweb.com\/solved\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/jassweb.com\/solved\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/jassweb.com\/solved\/#organization","name":"Jass Web","url":"https:\/\/jassweb.com\/solved\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/jassweb.com\/solved\/#\/schema\/logo\/image\/","url":"https:\/\/jassweb.com\/wp-content\/uploads\/2021\/02\/jass-website-logo-1.png","contentUrl":"https:\/\/jassweb.com\/wp-content\/uploads\/2021\/02\/jass-website-logo-1.png","width":693,"height":132,"caption":"Jass Web"},"image":{"@id":"https:\/\/jassweb.com\/solved\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/jassweb.com\/solved\/#\/schema\/person\/65c9c7b7958150c0dc8371fa35dd7c31","name":"Kirat","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/jassweb.com\/solved\/#\/schema\/person\/image\/","url":"https:\/\/jassweb.com\/solved\/wp-content\/litespeed\/avatar\/1261af3c9451399fa1336d28b98ea3bb.jpg?ver=1775798750","contentUrl":"https:\/\/jassweb.com\/solved\/wp-content\/litespeed\/avatar\/1261af3c9451399fa1336d28b98ea3bb.jpg?ver=1775798750","caption":"Kirat"},"sameAs":["http:\/\/jassweb.com"],"url":"https:\/\/jassweb.com\/solved\/author\/jaspritsinghghumangmail-com\/"}]}},"_links":{"self":[{"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/posts\/3883","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/comments?post=3883"}],"version-history":[{"count":0,"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/posts\/3883\/revisions"}],"wp:attachment":[{"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/media?parent=3883"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/categories?post=3883"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/jassweb.com\/solved\/wp-json\/wp\/v2\/tags?post=3883"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}