|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object javax.swing.event.EventListenerList
public class EventListenerList
EventListener のリストを格納するクラスです。1 つのインスタンスを使用して、このリストを使用しているインスタンスの (すべてのタイプの) すべてのリスナーを格納できます。タイプ保証された API (JavaBeans 仕様への準拠が望ましい) およびイベント通知メソッドをリスト内の適切な EventListener に送信するメソッドの提供は、EventListenerList を使用しているクラスが行います。 このクラスが提供する主な利点は、リスナーがない場合には比較的安上がりで、イベントリスナーのリストを 1 つの場所で直列化して、正しく使用した場合にはある程度のマルチスレッドに対する安全性が提供されることです。 使用例:たとえば、FooEvent を送出するクラスを定義して、そのクラスのユーザーが FooListener を登録し、FooEvent が発生したら通知を受け取ることができるようにする場合は、クラスの定義に次のコードを追加する必要があります。
EventListenerList listenerList = new EventListenerList(); FooEvent fooEvent = null; public void addFooListener(FooListener l) { listenerList.add(FooListener.class, l); } public void removeFooListener(FooListener l) { listenerList.remove(FooListener.class, l); } // Notify all listeners that have registered interest for // notification on this event type. The event instance // is lazily created using the parameters passed into // the fire method. protected void fireFooXXX() { // Guaranteed to return a non-null array Object[] listeners = listenerList.getListenerList(); // Process the listeners last to first, notifying // those that are interested in this event for (int i = listeners.length-2; i>=0; i-=2) { if (listeners[i]==FooListener.class) { // Lazily create the event: if (fooEvent == null) fooEvent = new FooEvent(this); ((FooListener)listeners[i+1]).fooXXX(fooEvent); } } }foo は適切な名前に、fireFooXxx は適切なメソッド名にそれぞれ変更する必要があります。FooListener インタフェースの通知メソッドごとに起動メソッドが必要です。
警告: このクラスの直列化されたオブジェクトは、今後の Swing リリースと互換ではなくなる予定です。現在の直列化のサポートは、短期間の運用や、同じバージョンの Swing を実行するアプリケーション間の RMI に適しています。JDK Version 1.4 以降、すべての JavaBeans™ の長期間の運用サポートは、java.beans
パッケージに追加されています。詳細は、XMLEncoder
を参照してください。
フィールドの概要 | |
---|---|
protected Object[] |
listenerList
|
コンストラクタの概要 | |
---|---|
EventListenerList()
|
メソッドの概要 | ||
---|---|---|
|
add(Class<T> t,
T l)
指定された型のリスナーとしてリスナーを追加します。 |
|
int |
getListenerCount()
このリスナーリストのリスナーの総数を返します。 |
|
int |
getListenerCount(Class<?> t)
このリスナーリストの、指定された型のリスナーの総数を返します。 |
|
Object[] |
getListenerList()
イベントリスナーのリストを、リスナーとリスナータイプのペアの配列として返します。 |
|
|
getListeners(Class<T> t)
指定された型のすべてのリスナーの配列を返します。 |
|
|
remove(Class<T> t,
T l)
指定された型のリスナーとしてリスナーを削除します。 |
|
String |
toString()
EventListenerList の文字列表現を返します。 |
クラス java.lang.Object から継承されたメソッド |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
フィールドの詳細 |
---|
protected transient Object[] listenerList
コンストラクタの詳細 |
---|
public EventListenerList()
メソッドの詳細 |
---|
public Object[] getListenerList()
public <T extends EventListener> T[] getListeners(Class<T> t)
ClassCastException
- 指定されたクラスが EventListener に割り当てられない場合public int getListenerCount()
public int getListenerCount(Class<?> t)
public <T extends EventListener> void add(Class<T> t, T l)
t
- 追加されるリスナーの型l
- 追加されるリスナーpublic <T extends EventListener> void remove(Class<T> t, T l)
t
- 削除されるリスナーの型l
- 削除されるリスナーpublic String toString()
Object
内の toString
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。