Android工程业务繁多时,为了聚合业务,通常会根据业务类型拆分成不同的module,例如ChatLibrary,PayLibrary,FaceIdentifyLib等,然后让主工程分别依赖这些子module,方便主工程随时调用子module的信息。
但是此时子module并未依赖主工程,自然也无法访问主工程的数据。
那么用EventBus事件总线呢?试验过都会被modules间的这道墙所隔离。(EventBus只能用在单module里通信)
可以使用boardcast ,这是安卓本身系统带有可以整个系统里告知信息,通过boardcast广播应该是可以做到的传输的,唯一不好的地方就是其效率不高(至少会比EventBus要低)
数据库?但是如果你一直在监听着某些数据的变化,也会产生有一定的消耗的。
那为何module间不直接相互依赖,这样不就可以解决问题呢?倘或一个module被多个module依赖,那些module都会调用这个module的方法,那么这样移除这个module将会是致命的,将需要增加以后维护的难度。我们设计的初衷是松耦合。
主工程可以单向访问子module。
1.在子module中定义接口,然后让主工程实现。
2.子module也实现该接口,并且实现类中定义一个方法获取主工程实现类的实例(参数列表时 接口类型)。