« 4th MEDIA(@nifty TV)の解約 | トップページ | Javaでニコニコ動画風のプレイヤを作れるか »

2007/11/04

Swing入門以前 - Swingのスレッドポリシー(1)

Swingのことをweb検索しているとよくスレッドの話題を見かける。javax.swingパッケージのJavadocにもセクションが設けられているくらい重要な事項らしい。しかし、Swing入門書のサンプルコードを書き写している限りではスレッドの話なんて一言も出てこなかったが?

というわけで、スレッドについて調査することにした。「入門以前」としては、前回までの概念モデルと今回からのスレッドの調査で完了としよう、と考えている。

今回はThe Java Tutorialsのうち、Concurrency in Swingを主に参考にしている。

 

スレッドの種類

Swingで扱うスレッドは、以下の3種類に大別できる。2列目の記述は、現段階で理解している内容である。

イニシャルスレッド
(initial theads)
mainメソッドが実行される、いわゆるメインスレッドをイメージすればよい。単純なSwingアプリケーションでは、何も行わない。
イベントディスパッチスレッド
(EDT;event dispatch thread)
Swingコンポーネントのコントロールはすべてこのスレッドで実行する必要がある(ただし例外は有る)。
ワーカースレッド
(worker threads)
一般的に使用されているワーカースレッドと同じイメージ。バックグラウンドスレッドとも呼んでいるようだ。

ここで疑問点。

  • メインスレッド(イニシャルスレッド)とイベントディスパッチスレッドは別物か?

イベントディスパッチスレッドというものがメインスレッドと同一のものであるならば、入門書では敢えてスレッドについて触れていないのもうなづける。…が、これは別物である。

ここが誤解していた点であり、理解を妨げていた箇所なのだが、Webでよく見かける「Swingはシングルスレッド設計」というような文章、これは「Swingコンポーネントのコントロールはイベントディスパッチスレッドという単一のスレッドで実行する必要がある」ということであり、Swingプログラムがシングルスレッドというわけではない(少なくともイニシャルスレッドとイベントディスパッチスレッドの2スレッドは使用される)。

 

イベントディスパッチスレッドを意識しなくてよい理由

Swingアプリケーションをプログラミングしてきたので、もちろんSwingコンポーネントのコントロールは行っている。しかし今までイベントディスパッチスレッド(EDT)は全く意識してこなかった。何故だろうか。

ここで、いつSwingコンポーネントを操作した(Swing系オブジェクトのメソッドを使用した)か考えてみた。以下の2点が心当たりとしてあった。

  • (A):mainメソッドの中でJFrameのオブジェクトを作成(new)して表示(setVisible)した。
  • (B):actionPerformedメソッドの中に、ボタンが押されたときに文字列を表示するようにした。

上記の(A), (B)は、Swingのスレッドポリシーというものに合致してるのか反しているのか?

« 4th MEDIA(@nifty TV)の解約 | トップページ | Javaでニコニコ動画風のプレイヤを作れるか »

コメント

この記事へのコメントは終了しました。

トラックバック


この記事へのトラックバック一覧です: Swing入門以前 - Swingのスレッドポリシー(1):

« 4th MEDIA(@nifty TV)の解約 | トップページ | Javaでニコニコ動画風のプレイヤを作れるか »

other sites

  • follow us in feedly
  • github
  • stackoverflow

ソフトウェアエンジニアとして影響を受けた書籍

  • Christain Bauer: HIBERNATE イン アクション

    Christain Bauer: HIBERNATE イン アクション
    理論と実践が双方とも素晴らしい製品であるHibernate。本書はそのプロダクトを書名に冠していますが、Hibernateを使うつもりがなく、ORマッピングの解説書として読むにしても十分な良書です。Second EditionとしてJava Persistence With Hibernateという書籍も出版されていますが、残念ながら現在のところ 和訳はされていません。-インアクションは2.xの、Java Persistence-は3.1の頃のものなので、最新版とはちょっと違うところもあることに注意。 (★★★★★)

  • アンドリュー・S・タネンバウム: 分散システム 原理とパラダイム 第2版

    アンドリュー・S・タネンバウム: 分散システム 原理とパラダイム 第2版
    クライアント/サーバシステムを構築する上で必要となる知識が総論されてます。Web技術者も、フレームワーク部分を開発するのであれば必読。 (★★★★★)

  • Joel Spolsky∥著: ジョエル・オン・ソフトウェア

    Joel Spolsky∥著: ジョエル・オン・ソフトウェア
    前述の書籍「ソフトウエア開発プロフェッショナル」をより砕いたもの、という感じでしょうか。 前書きではプログラマでなくSE向けの本のように書かれているが、プログラマが読んでも面白い本であると思われます。 SEになった新人(あるいはそういう会社に入る/入りたての人)にとっては、これからどういったことが仕事を遂行していく上で起こりえるのか、どのように考えて行なっていけばいいのか決定する助けになると思います。 元は″Joel on Software″というブログの記事で、web上でも一部日本語で読めます。 http://japanese.joelonsoftware.com/ (★★★)

  • ドナルド・C・ゴース,ジェラルド・M・ワインバーグ: ライト、ついてますか

    ドナルド・C・ゴース,ジェラルド・M・ワインバーグ: ライト、ついてますか
    問題解決(一昔前のの流行語で言うところの『ソリューション』)能力は、システムエンジニアのスキルとして備えるべきもののうちのひとつです。しかし、これは難しい。学校で出されるテストと違い、唯一の、(問題提出者が想定している)解を求めるだけが「問題解決」では無いからです。そもそも、何が問題なのか、それは本当に問題なのか、それは本当に解決すべき問題なのか、その問題解決方法は正しいのか、などを解決しなければ、「その解は正しいのか」に辿りつくことができません。この本の最も良いところのひとつは、本があまり厚くないこと。すぐに読めるし、何回も読み返す気になるでしょう。 (★★★★★)

  • スティーブ・マコネル: ソフトウエア開発プロフェッショナル

    スティーブ・マコネル: ソフトウエア開発プロフェッショナル
    コードコンプリートで有名なスティーブマコネルの著書。新人SEに読んで欲しい。個人として業界の中でどうあるべきか、組織としてどうあるべきか、SEのプロ意識とは?SEの心構え概論、といったところでしょうか。また、業界における資格の重要性についても説かれています。この業界では資格が特に軽んじられる傾向がありますが、この傾向はどんな弊害をもたらすのか、将来的にこの業界は資格に対してどのような姿勢で臨んでいくべきなのか。日経BP社では(他の出版社もだが)最近、似たような類いのあまり面白くない書籍が乱出版されていますが、この本は別格だと思うので安心して購入して欲しいと思います。 (★★★★★)

無料ブログはココログ