この38年問題は、プログラムを作成するときunixtimeに64bit定数を使うだけで解決できます。 実際64bitのPHPはUnixTimeが64Bitになっているのが確認できます。 問題が起きたメンバーのPCは、64bitのWindowsだったのですが、 開発には32bitのPHPしか入っていないXAMPP(開発環境)をつかっていて、unixtimeが32 bitになってしまっていました。 開発環境上では気持ち悪いそこで今回は32Bit版OSやソフトウェアが使えなくなる38年問題についてご紹介します。 32Bit OSは38年1月19日12時14分7秒以降に日付のカウントが狂う WindowsやUNIXは1970年1月1日から一秒単位でカウントしており、32Bit OSでは38年1月19日12時14分7秒に当たるここでは38年問題の対策・解決策についてご紹介したいと思います。 32ビットから64ビット整数型に変更? ralfsfotoseite / 38年問題の仕組みはbit数が不足していることによりtime_tがオーバーフローしてしまうことに起因するものでしたね。 つまり、bit数を増やすことによって回避することが可能です。 32bitから64bit整数型に変更することではるかに多くの数を表すことができる
Viprpg もしもで学ぶ38年問題 ニコニコ動画
2038年問題 対策
2038年問題 対策-38年問題カウントダウン時計 世界標準時38年1月19日3時14分8秒(日本時間12時14分8秒) C言語は通常時刻を1970年1月1日000を起点に2進数で頭の一桁を±に残り31桁を経過時間(単位 秒)の計32桁で表しています。ただし、Windowsは大半がパソコン(個人)向けなので影響が少ないですし、マイクロソフトはすでに対策をとっています。 24年後に古いWindows、古いソフトを使っている人はいないでしょうから、大きな問題としてみられていません。 影響が大きいのは「38年問題」です。 ウェブサイトなど外部からのアクセスを受け付けるシステム(サーバー)は、多くがWindowsではなく「Unix系OS」
結論 ・「38年問題」とは、38年1月19日3時14分7秒(utc)を過ぎると、コンピュータが誤作動する可能性があるとされている問題 ・コンピュータの時刻表現で広く使用されている「unix時間」は、1970年1月1日0時0分0秒からの経過秒数で時間を計測している ・経過秒数は、伝統的な実装ではそもそも38年問題ってどういう問題? まず知ってる人も多いけど、 38年問題 について解説 これは 38年1月19日3時14分7秒 を過ぎると、プログラムが誤作動する問題のことです。 伝統的な実装ではtime_tをintとし、そのintは符号つき32ビットであった。 引用元 38年問題つまり、long 型が 64bit で定義されている環境 (処理系) でアプリを コンパイル すれば、time_t 型で扱える年数が格段に増えて、 38年問題 を回避できるはず。 最近の環境ではそうなっていることが多いと思うので、新しめの環境でアプリを コンパイル すれば、だいたい 38年問題 対策は出来ていることになるのだろう。 # 時刻を表すのに time_t 型を使わず、int 型などを使っ
19年5月7日 Linux 51がリリース, 新しい非同期I/ Oインタフェース, 38年問題対策など Linus Torvaldsは5月5日 (米国時間 ) , 「 Linux 5 1」 の正式公開をアナウンスした。 約2ヵ月の開発期間と合計7本のリリース候補 (RC) 版を経ての公開となる対策 対策としては Datetime型を使う 整数型を使う という方法があるみたいです。 1 Datetime型を使う場合の注意点 DATETIME型は、 タイムゾーン の影響を受けません。 そのため、 タイムゾーン が UTC → JST に切り替えても同じ値が入り、日付データが絶対値とならない可能性があります https//qiitacom/juve_534/items/a9f9f72d49fe8 2 整数方を使う場合の注意点38年問題への対策 それでは38年問題を引き起こさないようにするためにはどのような対策があるでしょうか。 プログラムを修正する方法としては、変数の型をより値の範囲の広い型に変更することが挙げられます。 32bit型符号付変数から64bit型符号付変数に変更すれば、値の範囲は時刻の計算処理においては現実的に考慮しなくてよい巨大な数値になるため、問題を回避する
36年問題year 36 problemとは、インターネットなどのIPネットワーク上での時刻合わせに用いられるNTP(Network Time Protocol)の仕様により、西暦36年の特定の日時以降の日付と時刻を正しく扱えなくなる問題。2^32/24*60*60*>約 136年でラップアラウンドします。 符号が考慮されていなければ年=38年に問題が生じます。 例えば、localtimeは、 Borland C 52 for Win32 負数を与えると例外発生プログラム停止 Borland C 452 (DOS) 負数でなくても38年の特定日より 1970年38年問題 38年1月19日 3時4分8秒 utc(12時14分8秒 jst)にコンピューターの時計が壊れる問題。 1970年1月1日 0時0分0秒からカウントアップしてると、上記のタイミングで桁あふれする。 32ビット整数型だと2,147,4,647秒が上限。21億秒って。。 だいたい68年。
38年1月19日 以降の時刻を表現できません。 対策1 C言語の time_t を32ビットから64ビットに変更する。 (64ビット整数という変数はC言語にはないので作るしかないが・・・)こうすれば、もう永遠に時刻問題を気にする必要はなくなります。 だって、2922億年まで大丈夫ですから・・・(ちなみに、地球ができてまだ45億年・・・そして、太陽が燃え尽きるまでの寿命はあと50億年といわれよろしくお願いします。 Armadillo460においてNTPを使用したいと思っていますが Linuxの38年問題で引っかかっているようで 未来で設定できない年月日が出てしまっています。 99年までは設定できるようにしたいのですが 現状、通常のやり方では回避できそうもないので 何か良い回避方法がない32bitアプリの38年問題回避方法 38年問題とは、32bitアプリケーションでは通常符号ありlong intで扱うため、38年でオーバフローする問題です。 その回避策として一般的なのが、独自にlong long intで64bitの変数を作るか、符号なしlong intで処理という方法らしいです。
38年問題とは エンジニア向けの説明 時は流れて年。 私は意図せず基幹システムの保守っぽい仕事をしていたのですが、 とある調査中、とあるカラムに「38年01月19日12時14分秒」という値がボコボコボコボコ入っているのを見つけてしまいました。38年問題はOSの問題 00年問題や25年問題は、いずれもデータやアプリケーションソフトウェアの問題ですので、2桁表示の暦を書きかえれば(00年問題は、00年がうるう年とカウントされないことによる問題も含んでいましたが)、ほとんどのケースはクリアすることができました。 ですが、 38年問題は、そのような『書き換え』によって回避できる問題ではありません 。 0038年1月19日12時14分7秒になると不具合が発生する可能性があると考えられているのでしょう。 00年問題のときと同様の懸念です。 試しに、Windows10の日時を50年に変更して再起動してみましたが、 起動できました。
まず38年問題というのをご存じでしょうか 38年問題 Wikipedia 38年問題(にせんさんじゅうはちねんもんだい)は、38年1月19日3時14分7秒(UTC、以下同様)を過ぎると、コンピュータが誤動作する可能性があるとされる年問題。
0 件のコメント:
コメントを投稿