Observable 观察类

Observable

  1. 创建被其他程序观察的子类
  2. 子类发生变化时,观察类会注意到,观察类必须实现Observer接口,观察者注意到被观察者发生变化时会调用update()方法
  3. 被观察者发生变化时要调用setChange方法
  4. 被观察者需要调用notifyObservables()进行通知,观察者会调用update方法
  5. 可以设置添加多个观察者

使用示例

实现Observer接口

public class Watcher implements Observer{

    @Override
    public void update(Observable o, Object arg) {
       System.out.println(o);
       System.out.println(arg);
       System.out.println("update()\t" + arg);
        
    }

}

继承Observable类

public class BeingWatcher extends Observable{

    public void counter(int period) {
        for(;period > 0;period--) {
            setChanged();
            notifyObservers(period);
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
}

测试方法

    BeingWatcher b = new BeingWatcher();
        Watcher w = new Watcher();
        b.addObserver(w);
        b.counter(10);

输出

observable.BeingWatcher@2077d4de
10
update()	10
observable.BeingWatcher@2077d4de
9
update()	9
observable.BeingWatcher@2077d4de
8
update()	8
observable.BeingWatcher@2077d4de
7
update()	7
observable.BeingWatcher@2077d4de
6
update()	6
observable.BeingWatcher@2077d4de
5
update()	5
observable.BeingWatcher@2077d4de
4
update()	4
observable.BeingWatcher@2077d4de
3
update()	3
observable.BeingWatcher@2077d4de
2
update()	2
observable.BeingWatcher@2077d4de
1
update()	1
### 关于 Observable 的使用和实现 #### Vue 中的 `Vue.observable` `Vue.observable` 是 Vue.js 提供的一种创建响应式对象的方法。这使得开发者可以在不依赖组件的情况下管理状态变化,从而让代码更简洁、易读且易于维护[^1]。 ```javascript // 创建一个可观察的对象 const state = Vue.observable({ count: 0, }); function increment() { state.count++; } console.log(state.count); // 输出当前计数值 increment(); console.log(state.count); // 增加后的计数器值会自动更新并反映出来 ``` 此功能特别适用于构建复杂的应用逻辑或处理跨多个组件共享的状态时保持数据同步。 #### RxJS 中的 Observable RxJS (Reactive Extensions for JavaScript) 库提供了强大的流控制机制来处理异步事件序列。其中的核心概念就是 Observables, 它允许订阅者监听来自发布者的值的变化,并作出相应的反应[^3]。 ```typescript import { Observable } from 'rxjs'; const observable = new Observable((subscriber) => { subscriber.next('Hello'); setTimeout(() => { subscriber.next('World!'); subscriber.complete(); }, 1000); }); observable.subscribe( value => console.log(value), // 处理正常消息 error => console.error(error), // 错误处理 () => console.log('完成') // 当Observable结束时调用 ); ``` 这段代码展示了如何定义一个简单的 Observable 并对其进行订阅操作,在接收到新值时触发回调函数执行特定的任务。 #### Java 中的 Observable 模式 Java 中虽然没有直接名为 “Observable”的内置,但是可以通过第三方库如 RxJava 或者利用接口模拟 Observer 设计模式达到相同的效果。对于多线程环境下的安全通信,则推荐采用 java.util.concurrent 包内的高级集合型作为替代方案[^2]。 ```java import io.reactivex.rxjava3.core.Observable; import io.reactivex.rxjava3.disposables.Disposable; public class Main { public static void main(String[] args) { Disposable disposable = Observable.just("Alpha", "Beta", "Gamma") .subscribe(System.out::println); // 记得清理资源 disposable.dispose(); } } ``` 上述例子中引入了 RxJava 来展示基于 JVM 的 Reactive 编程风格;而针对传统场景下可能涉及到的并发问题给出了建议性的解决方案——即优先选用经过优化设计的数据结构以确保性能与稳定性兼备。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值