OSとプログラミングの「時間」に関する常識:プログラマーの常識をJavaで身につける(4)(3/3 ページ)
本連載は、Java言語やその文法は一通り理解しているが、「プログラマー」としては初心者、という方を対象とします。Javaコアパッケージを掘り下げることにより「プログラマーの常識」を身に付けられるように話を進めていきます。今回は、「時間」について。OSの時間はどこから取得されるか、グレゴリオ暦とユリウス暦の境目などの常識と時間に関するクラスについて解説します。
日時を文字列へ変換[java.text.SimpleDateFormat]
日時型を文字列に変換するには、java.text.SimpleDateFormatクラスを利用します。ここでは、java.util.Date型から、年月日時分秒からなる文字列へ変換する例を示します(※フォーマットの指定方法などの詳細は、SimpleDateFormatクラスのAPIドキュメントをご参照ください)。
*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***
実行結果
2007/03/20 14:42:15
タイマーとタスクって何だ?
ここからは話を変えて、指定の時間だけスレッドの実行を止めたり、あるいは指定の時間間隔でスレッドを動作させるためのプログラミングを紹介していきます。
スレッドの一時的な実行停止
まず、スレッドの一時的な実行停止について学んでいきましょう。スレッドの一時停止を見る前に、一時停止とは関係のない、単純な繰り返しのプログラミングを見ていきます。下記のソースコードを実行してください。
*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***
実行結果
処理1回目
処理2回目
処理3回目
処理4回目
処理5回目
処理6回目
処理7回目
処理8回目
処理9回目
処理10回目
実行すると、即時に処理1回目から処理10回目まで繰り返されます。ごく普通の挙動ですね。
次に、これをゆっくり実行するように変更してみましょう。下記のソースコードを実行してください。
*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***
java.lang.Thread.sleep(ミリ秒)メソッドにより、スレッドの実行を一時停止できることを確認してください。
[java.util.Timer]と[java.util.TimerTask]で定期的な実行
先の例では、プログラム上に一時停止の実装が記述されていました。そして、それにより定期的な実行が実現できていた、と見ることもできます。
Java言語APIには、このような定期的な実行や定時実行を実現するためのjava.util.Timerクラスがありますので、これを見ていきましょう。java.util.Timerクラスを利用する場合には、Timerクラスとjava.util.TimerTaskクラスの2つを組み合わせて利用します。
*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***
この例では、5秒後にタスクを実行し、以降毎秒タスクを実行するようなサンプルとなっています。上記2つのソースコードを実行してください。
実行結果
5秒後に一度タスク実行し、続けて毎秒タスク実行を行います。
処理1回目
処理2回目
処理3回目
処理4回目
処理5回目
処理6回目
処理7回目
処理8回目
処理9回目
処理10回目
15秒経過したので、mainを終了します。
処理11回目
処理12回目
処理13回目
処理14回目
処理15回目
処理16回目
処理17回目
処理18回目 ……以降、半永久的に動作し続けます。
5秒経過した後、前のThread.sleepの例で確認したのと同様の実行結果が得られます。ところが、「15秒経過したので、mainを終了します。」のメッセージが出力された後も引き続き動作し続けています。
この実行を停止させるためには、該当のJavaVMを停止させる必要があります。Eclipseであれば、コンソールビュー上の終了(赤い四角)ボタンを押して停止させてください。
これはTimerクラスのパラメータなしコンストラクタを利用した場合には、スレッドが動作し続けるような仕様になっているためです。
Timerを完全に止めるには?
mainスレッドが停止したら、Timerも停止するようにするためには、下記のように変更します。下記のソースコードを実行してください。
*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***
実行結果
5秒後に一度タスク実行し、続けて毎秒タスク実行を行います。
処理1回目
処理2回目
処理3回目
処理4回目
処理5回目
処理6回目
処理7回目
処理8回目
処理9回目
処理10回目
15秒経過したので、mainを終了します。
処理11回目
mainが終了すると、JavaVMが終了することを確認してください。Eclipseでは、終了ボタンが灰色に戻っている灰色に戻っていることでも確認できます。
次回は「国際化プログラミング」の常識について
次回は、国際化プログラミングの常識についてです。java.util.Locale、java.util.TimeZoneクラスで国・ロケールの概念、java.util.Currencyクラスで通貨などについて学んでいきましょう。
筆者紹介
blanco Framework(コミッタ)
伊賀 敏樹(いが としき)
ハンドル:いがぴょん
1968年生まれ。現在、NTTデータ ビジネスブレインズ 第一SI事業部 ソリューショングループ所属。システム開発の技術支援などに従事する。仕事におけるJava言語とのかかわりは1998年から。 現在 blanco Frameworkというオープンソースによるソースコード自動生成タイプの開発フレームワーク提供に取り組んでいる。 趣味はヴァイオリン演奏。アマチュアオーケストラで演奏することもある。
ホームページ
いがぴょんの日記ウェブページv2(1996年から続けているWeb日記)
主な著書
「やさしく学ぶ基礎からのJDBC」
「Javaプログラミング[アプリケーション編]ステップアップラーニング」
Copyright © ITmedia, Inc. All Rights Reserved.