- 官方使用的DCL单例并没有使用volatile,看样子关系不大
- 使用的是Handler+MainLooper,所有调用都是在UIThread
- 注册是synchronized,线程安全
- 对ArrayList进行删除时,从后向前比较,效率会高一点点
- 为了避免对同一个Intent的多次广播,在匹配一次后,会给filter置位,后续不进行匹配,全部结束后进行重置(line:200)。貌似比不置位用ArrayList.contains效率要高。实际上比HashSet的空间复杂度也要低。HashMap源码
话说,这段代码写的是真垃圾,真的。。。
不过可以使用LocalBroadcastManager做一个非常通用的Observer型的Data Binding方法模式,还是很有用的。