写在前面
最近单位忙到爆,好不容易闲下来,抽空看了看Retrofit的源码,发现用的是动态代理,学Java的时候代理模式就没怎么学好,到现在早就忘光了,结合Google,从静态代理模式重新理解了一下.
静态代理
委托代理模式是软件设计中的一项基本技巧。在委托代理模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给另一个对象来处理。
看着上边的解释一脸懵逼,简单来说就是 A产生事件传给B,B再将事件传给C实现事件的处理,B在传给C事件之前可以先进行过滤和处理.这样也就进行了代码解耦.
举个栗子
用一个例子来进行理解:
一个演员通常都会有一个经纪人,平时负责联络商务会演的都是经纪人,经纪人联络好之后,在将时间场地告诉演员,演员到时间过去演唱.此处引入一个煎饼侠中的案例来进行理解.
大鹏过气,没钱,刚好柳岩的朋友结婚,托柳岩找个主持人,大鹏和柳岩的朋友之间互相并不认识,柳岩的朋友委托柳岩找主持人,大鹏代理了主持这个事情(虽然最后没主持成吧,但是这里只做例子,不看剧情).
代码实现
首先是主持这个事情
interface IHost {
//主持
fun host()
}
柳岩和大鹏都会主持,所以他们都要实现这个接口:
class Liuyan : IHost{
override fun host() {
println("柳岩帮忙找主持人")
}
}
object DaPeng : IHost{
override fun host() {
println("大鹏主持婚礼")
}
}
然后是柳岩的朋友,现在结婚了,需要找个婚礼主持人,委托给柳岩,所以柳岩的朋友委托给柳岩时,不能出现大鹏.
fun main(args: Array<String>) {
println("我要结婚了,需要人主持婚礼")
var liuyan = Liuyan()
liuyan.host()
}
运行结果:
柳岩要帮忙找主持人,正好大鹏缺钱,想变相帮助他一下,就把这个事件委托给了大鹏:
class Liuyan : IHost by DaPeng{
//Kotlin下委托代理用by关键字
override fun host() {
println("柳岩帮忙找主持人")
DaPeng.host()
}
}
再来运行一次:
这样,柳岩就把主持这个事情交给了大鹏,柳岩的朋友联系不到大鹏,而大鹏呢,并不认识柳岩的朋友,中间没有任何耦合关联.如果现在柳岩把主持这个事情交给了别人,不让大鹏来参与,就只需要改自身就可以,大鹏依旧会主持,而柳岩的朋友也依旧要结婚,没有任何影响.
class Liuyan : IHost by DaPeng{
override fun host() {
println("柳岩帮忙找主持人")
println("柳岩把主持的事情交给了别人")
}
}
运行结果:
相同的例子其实生活中还有很多,比如:我们北漂找住的房子,房子多的房东想把房子租出去,但是除此之外我们还有工作,不能无时无刻都去找租户or房东,所以有了中介的产生,房东不管什么时候去找中介都可以把房子租出去,我们不管什么时候去找中介都能租到房子,而房东和租户之见并不需要见面......可以自己写写这个例子.
结尾
结尾照旧推荐一首歌,我们不一样,有啥不一样........