zookeeper源码解析(五)

本文深入探讨Zookeeper的WatchManager接口及其实现,详细分析了IWatchManager中的size方法,强调其在多线程环境下的安全性。同时,文章还介绍了addWatch方法的工作原理,包括如何遍历watchTable并更新watch数量,以及如何维护watch2Paths和watcherModeManager的映射关系。
摘要由CSDN通过智能技术生成

2021SC@SDUSC

IWatchManager

zookeeper的watch管理器接口

    //将watcher加入指定路径,返回布尔值,若为真,则说明原本对应该路径不存在watcher
    boolean addWatch(String path, Watcher watcher);

    
    //将watcher加入指定路径,返回布尔值,若为真,则说明原本对应该路径不存在watcher
    //并且设置了watcher模式
    default boolean addWatch(String path, Watcher watcher, WatcherMode watcherMode) {
        if (watcherMode == WatcherMode.DEFAULT_WATCHER_MODE) {
            return addWatch(path, watcher);
        }
        throw new UnsupportedOperationException(); 
    }

    
    //检查指定的路径是否存在指定的watcher
    boolean containsWatcher(String path, Watcher watcher);

    
    //移除指定的路径的指定的watcher
    boolean removeWatcher(String path, Watcher watcher);

    
    //移除watcher
    void removeWatcher(Watcher watcher);

    
    //给指定路径分配watch event,返回已经被通知的所有watcher
    WatcherOrBitSet triggerWatch(String path, EventType type);

    
    //给指定路径分配watch event,返回已经被通知的所有watcherÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值