当前位置: 移动技术网 > IT编程>移动开发>Android > 如何利用Kotlin实现极简回调

如何利用Kotlin实现极简回调

2019年07月30日  | 移动技术网IT编程  | 我要评论

商丘医专教务处,nba新浪直播,后藤理沙

前言

在各种开发场景中,回调都有着广泛的应用,命名往往是各种callback和listener,其中在android中接触最早也最常用的可能就是view.onclicklistener了。

 mbtn.setonclicklistener(new view.onclicklistener() {
   @override
   public void onclick(view v) {
    log.d("mm","click");
   }
  });

不过写多了也有点烦恼,我只想打印一条日志,却写了这么多代码。不过好在这个接口里面只包含一个方法,但换做一些包含方法数量比较多的回调就显得比较臃肿了:

 medit.addtextchangedlistener(new textwatcher() {
   @override
   public void beforetextchanged(charsequence s, int start, int count, int after) {
    
   }

   @override
   public void ontextchanged(charsequence s, int start, int before, int count) {

   }

   @override
   public void aftertextchanged(editable s) {

   }
  });

如果你想优化你的代码,让它们看起来更简洁优雅,可以试试kotlin的中的一些方法。

简化

先来看下kotlin中的回调:

  mbtn.setonclicklistener(object :view.onclicklistener{
   override fun onclick(v: view?) {
    println("click")
   }
  })

好像一点也没简化嘛,不过因为在 kotlin 里函数也是参数的一种,在 java 中只包含一个方法的接口,在 kotlin 中都可以使用 lambda 表达式来达成一样的效果。

 mbtncallback.setonclicklistener { println("click") }

是不是简单很多了,但上面的用法仅适用于接口中只有一个方法的情况,如果存在多个方法的话,当然也可以简化了:

 medit.addtextchangedlistener {
   beforetextchanged { text, start, count, after -> println("beforetextchanged") }
   ontextchanged { text, start, before, count -> println("ontextchanged") }
   aftertextchanged { text -> println("aftertextchanged") }
  }

也可以按需调用其中任意个方法:

 medit.addtextchangedlistener {
   ontextchanged { text, start, before, count -> println("ontextchanged") }
  }

不过此处的addtextchangedlistener是一个扩展函数,需要我们来自己实现:

inline fun textview.addtextchangedlistener(init: textwatcherbridge.() -> unit) = addtextchangedlistener(textwatcherbridge().apply(init))

class textwatcherbridge : textwatcher {

 private var beforetextchanged: ((charsequence?, int, int, int) -> unit)? = null
 private var ontextchanged: ((charsequence?, int, int, int) -> unit)? = null
 private var aftertextchanged: ((editable?) -> unit)? = null

 override fun beforetextchanged(s: charsequence?, start: int, count: int, after: int) {
  beforetextchanged?.invoke(s, start, count, after)
 }

 override fun ontextchanged(s: charsequence?, start: int, before: int, count: int) {
  ontextchanged?.invoke(s, start, before, count)
 }

 override fun aftertextchanged(s: editable?) {
  aftertextchanged?.invoke(s)
 }

 fun beforetextchanged(listener: (charsequence?, int, int, int) -> unit) {
  beforetextchanged = listener
 }

 fun ontextchanged(listener: (charsequence?, int, int, int) -> unit) {
  ontextchanged = listener
 }

 fun aftertextchanged(listener: (editable?) -> unit) {
  aftertextchanged = listener
 }

}

原理就是实现一个扩展函数,把我们自己实现的textwatcherbridge加入到回调中,因为kotlin支持函数式编程,里面都是高阶函数。为了减少性能损耗,扩展函数声明为内联函数。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网