7.kotlin安卓实践课程-用kotlin写第一个activity对应M层

  1. 云栖社区>
  2. 博客>
  3. 正文

7.kotlin安卓实践课程-用kotlin写第一个activity对应M层

android_bigman 2018-06-16 13:56:00 浏览1019

简介

主要会通过安卓实战来讲解kotlin语法和实际应用,本教程设及知识点包括框架模式mvp+mvvm, Databinding(数据绑定框架),Dagger2(依赖注入框架),DeepLink(页面路由框架),Rxjava,RxAndroid(异步操作框架),Retrofit,Okhtttp等,不过本教程重点在kotlin所以这些框架需要了解可自行百度。

针对人群:Android中级以上,kotlin入门


上一篇文章讲了RandomPresenter的代码构成

在上篇RandomPresenter代码中有这么一段

mModel.getRandom(type)
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe({ res ->
                    if (!res.error) {
                        mView.onRandom(res.results[0])
                    }
                }, {}))

mModel.getRandom(type)这句话就是在mModel里去请求网络,具体实现我们看看

/**
 * Created by bigman on 18-05-17.
 */
class RandomModel
@Inject constructor(private val service:RandomService) :RandomContract.Model{

    override fun getRandom(type:String): Observable<JsonResult<List<FuckGoods>>> {
        return service.getRandom(type)
    }
}

这个RandomModel主要是提供了一个注入的构造函数,在这里它的构造函数里面传入了一个RandomService接口,这个接口的实现如下

/**
 * Created by liuguirui on 2018/5/17.
 */
interface RandomService {
    /**
     * 手气不错
     */

    @GET("random/data/{type}/1")
    fun getRandom(@Path("type") type:String): Observable<JsonResult<List<FuckGoods>>>
}

熟悉 Retrofit+Rxjava的同学应该很清楚这个接口类就是用来声明服务器接口和参数声明的,它和我们正常java写的retrofit接口没太大的区别,这里只有一个getRandom方法

  1. 然后让我们再回到RandomModel
class RandomModel @Inject constructor(private val service:RandomService) :RandomContract.Model

这里的constructor我们前面我们见过但是我没说,大概英文水平8都是八级以上肯定猜到是构造函数吧。

语法点:构造函数

1.分类

kotlin中构造函数一种主构造函数和次构造函数,而java是没有主次之分但是java也是支持多个构造函数的

2.主构造函数

  • 主构造函数是写在类名后面的,比如我们这里的class RandomModel @Inject constructor(private val service:RandomService),这就是主构造函数的一般形式
  • 主构造函数只能有一个,次构造函数可有可无
  • 主构造函数不能包含任何的代码,但是初始化的代码可以放到init函数里面,这个我们前面说过
  • 当主构造函数有注解或者可见性修饰符,需加 constructor 关键字,我们这里的代码就包含了注解

3.次构造函数
咱们这里没用到次构造函数没关系,kotlin的次构造函数和java的多个构造函数有点不同,kotlin的次构造函数必须直接或间接的委托给主构造函数
看以下代码

class Coder (name:String){
   //直接委托
    constructor(name: String,age:Int):this(name) {
    }
  //间接委托
    constructor(name: String, age: Int,score:Int) : this(name, age) {
    }
}

这里有几个点:

  • class Coder (name:String)这里其实就是主构造函数
  • 次构造函数必须用constructor关键字,而且必须用:冒号直接或间接委托给主构造函数
  • 直接委托就是this关键字去调用的,比如这里的constructor(name: String,age:Int):this(name)就是通过this(name)直接调用了主构造函数
  • 间接委托,比如这里的constructor(name: String, age: Int,score:Int) : this(name, age)是先用this(name, age)调用了第一个次构造函数,然后通过这个次构造函数间接的调用了主构造函数

然后我们回头看看RandomPresenter的构造函数,其实和这里的 RandomModel一样的主构造函数,看看它的代码

class RandomPresenter
@Inject constructor(private val mModel: RandomModel,
                    private val mView: RandomContract.View) : RandomContract.Presenter, BasePresenter()

其实这种形式在我们这个项目里非常常见大家以后见多了也就习惯了,我们顺便看完这个构造函数里的RandomContract的代码

/**
 * Created by bigman on 18-05-18.
 */
interface RandomContract{
    interface View{
        fun onRandom(goods:FuckGoods)

    }
    interface Model{

        fun getRandom(type: String): Observable<JsonResult<List<FuckGoods>>>
    }
    interface Presenter{

        fun getRandom(type: String)
    }

}

熟悉google官方的mvp框架的同学应该知道这个接口文件的意义,这就是一个简单的协议接口,同时提供了mvp三个核心层次不同的接口定义,其实就是面向接口编程的一种标准形式


欢迎一起交流,有问题加群交流

kotlin实战交流群群二维码.png