
- Java.util 包類
- Java.util - 首頁
- Java.util - ArrayDeque
- Java.util - ArrayList
- Java.util - Arrays
- Java.util - BitSet
- Java.util - Calendar
- Java.util - Collections
- Java.util - Currency
- Java.util - Date
- Java.util - Dictionary
- Java.util - EnumMap
- Java.util - EnumSet
- Java.util - Formatter
- Java.util - GregorianCalendar
- Java.util - HashMap
- Java.util - HashSet
- Java.util - Hashtable
- Java.util - IdentityHashMap
- Java.util - LinkedHashMap
- Java.util - LinkedHashSet
- Java.util - LinkedList
- Java.util - ListResourceBundle
- Java.util - Locale
- Java.util - Observable
- Java.util - PriorityQueue
- Java.util - Properties
- Java.util - PropertyPermission
- Java.util - PropertyResourceBundle
- Java.util - Random
- Java.util - ResourceBundle
- Java.util - ResourceBundle.Control
- Java.util - Scanner
- Java.util - ServiceLoader
- Java.util - SimpleTimeZone
- Java.util - Stack
- Java.util - StringTokenizer
- Java.util - Timer
- Java.util - TimerTask
- Java.util - TimeZone
- Java.util - TreeMap
- Java.util - TreeSet
- Java.util - UUID
- Java.util - Vector
- Java.util - WeakHashMap
- Java.util 包額外內容
- Java.util - 介面
- Java.util - 異常
- Java.util - 列舉
- Java.util 有用資源
- Java.util - 有用資源
- Java.util - 討論
Java Observable 類
介紹
Java Observable 類表示一個可觀察物件,或在模型-檢視正規化中的“資料”。以下是關於 Observable 的重要要點:
該類可以被子類化以表示應用程式希望被觀察的物件。
一個可觀察物件可以有一個或多個觀察者。
類宣告
以下是 java.util.Observable 類的宣告:
public class Observable extends Object
類建構函式
序號 | 建構函式 & 描述 |
---|---|
1 | Observable() 這將構造一個具有零個觀察者的 Observable。 |
類方法
序號 | 方法 & 描述 |
---|---|
1 | void addObserver(Observer o)
此方法將一個觀察者新增到此物件的觀察者集中,前提是它與集合中已有的某個觀察者不同。 |
2 | protected void clearChanged()
此方法指示此物件不再發生更改,或者它已經通知其所有觀察者其最新的更改,以便 hasChanged 方法現在將返回 false。 |
3 | int countObservers()
此方法返回此 Observable 物件的觀察者數量。 |
4 | void deleteObserver(Observer o)
此方法從此物件的觀察者集中刪除一個觀察者。 |
5 | void deleteObservers()
此方法清除觀察者列表,以便此物件不再有任何觀察者。 |
6 | boolean hasChanged()
此方法測試此物件是否已更改。 |
7 | void notifyObservers()
如果此物件已更改(如 hasChanged 方法所示),則通知其所有觀察者,然後呼叫 clearChanged 方法以指示此物件不再發生更改。 |
8 | void notifyObservers(Object arg)
如果此物件已更改(如 hasChanged 方法所示),則通知其所有觀察者,然後呼叫 clearChanged 方法以指示此物件不再發生更改。 |
9 | protected void setChanged()
此方法返回將此 Observable 物件標記為已更改;hasChanged 方法現在將返回 true。 |
繼承的方法
此類繼承自以下類的方法:
- java.util.Object
使用 Observer 示例新增觀察者並獲取更新
以下示例演示了 java.util.Observable.addObserver(Observer) 方法的用法。
package com.tutorialspoint; import java.util.Observable; import java.util.Observer; class ObservedObject extends Observable { private String watchedValue; public ObservedObject(String value) { watchedValue = value; } public void setValue(String value) { // if value has changed notify observers if(!watchedValue.equals(value)) { System.out.println("Value changed to new value: "+value); watchedValue = value; // mark as value changed setChanged(); // trigger notification notifyObservers(value); } } } public class ObservableDemo implements Observer { public static void main(String[] args) { // create watched and watcher objects ObservedObject watched = new ObservedObject("Original Value"); // watcher object listens to object change ObservableDemo watcher = new ObservableDemo(); // trigger value change watched.setValue("New Value"); // add observer to the watched object watched.addObserver(watcher); // trigger value change watched.setValue("Latest Value"); } public void update(Observable obj, Object arg) { System.out.println("Update called with Arguments: "+arg); } }
輸出
讓我們編譯並執行上述程式,這將產生以下結果:
Value changed to new value: New Value Value changed to new value: Latest Value Update called with Arguments: Latest Value
廣告