- 授权协议: MIT
- 开发语言: C/C++
- 操作系统: iOS
- 软件首页: https://github.com/coderyi/DecouplingKit
- 软件文档: https://github.com/coderyi/DecouplingKit
软件介绍
Podfile
平台:IOS,' 7.0 ' 荚' DecouplingKit ','〜> 0.0.2 '
DecouplingKit是一个用于模块之间解耦的方案。
当应用团队的人数增长到一定人数之后会分出业务线,这样就会就行模块化工作来隔离开各个业务线,以便让每个团队能够独立工作。通用的方案是采用cocoapods把业务代码分别到到各个仓库,一个业务线就是一个业务仓库,当然如果更大拆分力度的话,一个小模块就是一个cocoapods仓库。这样就对业务线就进行了物理路径的隔离,各个业务线就不能随便调用其他业务线的代码。不过对于一定要调用的话还是可以引入头文件来调用,所以本质上来讲根本没有解除各个业务仓库之间的耦合。
解除耦合其中一部分是业务线页面之间的跳转,现在流行的方案是通过路由器做。另外一部分很容易忽略就是业务线之间调用方法,属性等,所以就有了DecouplingKit这个中间层来解决这个问题.DecouplingKit之后的业务逻辑可以看下图。
DecouplingKit只有一个类DKServiceManager,用来加载服务列表DKService.plist,服务就是一个业务中类协议,里面有其他业务需要调用的方法,属性等.DKService.plist里面每一项有service和impl,service对于protocol,impl就是实现协议的类。
比如业务1需要调用业务2的方法,只需要DKServiceManager通过协议来找到对应业务2中的impl就可以了。其中协议会集中放在BussinessPublicService仓库,这里不依赖任何仓库,协议里面的方法对于入参和返回值都通过UIKit,Foundation等系统框架中类型,不需要自己的模型类。对于业务2的实现类只要实现对应的方法就好。
DKServiceManager既可以返回实例,也可以返回类方法,当然对于你如果实现了父协议DKServiceProtocol的sharedInstance方法,也可以返回单例。
DecouplingKit是基于BeeHive改造的,BeeHive包括AppDelegate管理和模块调用解耦两部分,DecouplingKit专注于模块调用解耦这部分,DecouplingKit只有一个类比BeeHive轻量,支持调用实例和类方法,属性。的另一种方式就是通过运行时来做,例如CTMediator,通过一个中间层(对应BussinessPublicService)来公布对应的接口,接口调用CTMediator(runtime)来实现,这也是一种非常好的方案。
免费:商业的未来
Chris Anderson / 中信出版集团 / 2015-10-1 / 35.40
《免费》,这是一个商业模式不断被颠覆、被改写的时代。一种商业模式既可以统摄未来市场,也可以挤垮当前市场——在我们这个现代经济社会里,这并不是一件不可能的事情。“免费”就是这样的一种商业模式,它代表了互联网时代的商业未来。 “免费”商业模式是一种建立在以电脑字节为基础上的经济学,而非过去建立在物理原子基础上的经济学。在原子经济中,随着时间的推移,我们周围的物品都在逐渐升值。但是在字节经济的网络......一起来看看 《免费:商业的未来》 这本书的介绍吧!
