安卓Kotlin大佬评价及入门实践

广而告之,打开支付宝首页搜索7273592领取12月份大红包

前言

2017年的谷歌 I/O全球开发者大会上,Google宣布了Kotlin 成为 Android 官方编程语言,个人猜想,应该和Oracle的专利之争有一点关系,但是最重要的还是要实实在在期望全面提升 Android 的开发效率和语言层面的特性支持,据公司的Ios同事讲,国内Ios开发语言还是OC占大多数,而swift在国外已经是主流了,咱码农灯塔也不能老守着古董级的 Java 不放。

下面是一些行业大佬对cotlin的评价

Dan Lew:
在不牺牲性能或者安全性的前提下,Kotlin 相比 Java 能够编写更加简洁易懂的代码。Kotlin 最终编译为字节码,因此能够表现的跟 Java 一样好,它跟 Java 有一样的编译时检查(同时具备 Java 没有的内建空类型检查)。更重要的,Kotlin 的语言特性和标准库函数能够编写简洁有效的代码。此外,Kotlin 拥有强大的生态系统。然而也有不足,PMD这类检查工具和静态分析工具的确是目前kotlin的短板,需要时间积累。

JakeWharton:
正类似于我们在 RxJava 中所经历的,这是 Android 移动开发快速地引入了新技术的另一个实例。现在 Kotlin 更为成熟了,我们将会在服务器端开发和已有的软件库中更多地看到它。无论出于何种原因,这些软件库需要更多的时间去采用这类更新的语言和新软件库。因此,很高兴能看到 Kotlin 得到了更多的关注。此外,Kotlin 非常关注自身的完全兼容性,并具有非常好的工具,这正是大量其它的 JVM 语言过去曾缺失的。

旧项目接入kotlin

1.android studio升级到3.0及以上版本
2.项目根目录build.gradle添加如下

buildscript {
    //需要添加的
    ext.kotlin_version = '1.3.10'//也可以直接写在路径上(cotlin 插件版本)
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.2.1'
        //需要添加的
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

3.在需要支持kotlin的module的build.gradle文件加上如下

apply plugin: 'com.android.application'
 //需要添加的
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'

android {
    compileSdkVersion GLOBAL_COMPILE_SDK_VERSION
    buildToolsVersion GLOBAL_BUILDTOOLS_VERSION

    defaultConfig {
      ...
    }

    sourceSets {
      ...
    }

    dexOptions {
       ...
    }

    // 签名信息
    signingConfigs {
       ...
    }

    buildTypes {
      ...
    }

    lintOptions {
        abortOnError false
    }

}

dependencies {
    ...
    //cotlin 需要添加的
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    //可以不添加的
    //在Java平台(JVM)上使用kotlin反射功能,需要在项目中添加kotlin反射库的jar包(kotlin-reflect.jar)! 
    implementation "org.jetbrains.kotlin:kotlin-reflect:$kotlin_version"
}

Java转Cotlin

  • 举个栗子
    打开CotlinActivity,将Java文件换换为Kotlin文件有几种方法,最简单的方法是通过Find Action并输入如下的命令convert java file to kotlin,如果没改过快捷键,默认的快捷键为 Ctrl+Shift+A;或者通过菜单栏的Code->convert java file to kotlin file
java_kotlin.png

转换后你应该可以看到Kotlin写的MainActivity

kotlin_coverted.png

Cotlin转Java

  • 同样举个栗子,还是上面的CotlinActivity
    打开CotlinActivity,点击菜单栏Tools->Kotlin->Show Kotlin Bytecode,可以看到Kotlin字节码
decompile_cotlin.png

点击Decompile,进行反编译,会得到如下

decompiled.png

Kotlin实战

  • Kotlin单例
class AppModel(defConfig: String, context: Context?) {
    companion object {
        var model: AppModel? = null
            get() {
                if (field == null) {
                    field = AppModel()
                }
                return field
            }
    }

    init {
        //构造函数
        Log.e("AppModel", "init1:$defConfig");
    }

    constructor() : this("hello kotlin", null) {
        //次级构造函数
        Log.e("AppModel", "init 2");
    }

    var data = ""

    fun update(data: String) {
        this.data = data
    }
}

Activity 调用 AppModel.model.update("b")

  • Kotlin & Rxjava
http.getWeather(lt, la, address)
         .doOnNext {
               it.air = WeatherBean.AirBean()
           }
         .observeOn(AndroidSchedulers.mainThread())
         .subscribe({
               WeatherModel.add(address, it)
               WeatherModel.save(false)//异步保存
           }, {
               Lg.e(it)
           })
  • Kotlin & Activity

import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.util.Log
import android.widget.Toast
import kotlinx.android.synthetic.main.activity_main.*

class CotlinActivity : AppCompatActivity() {

    val name: String
        get() = "hello world"

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        initView()
    }

    fun initView() {
        tv_main_content.setOnClickListener {  tv_main_content.text = name }
        for(i in 1..10){
            tv_main_content.text = i.toString()
        }
    }
}

  • Kotlin & 自定义View

class AwesomeImageView constructor(context: Context) : ImageView(context) {
    constructor(context: Context, attributeSet: AttributeSet) : this(context) {
        Lg.e("constructor1")
    }

    constructor(context: Context, attributeSet: AttributeSet, defStyleAttr: Int) : this(context) {
        Lg.e("constructor2")
    }

    private var mScreenWidth: Int = 0
    private var mFixWidth: Int = 0
    private var mFixHeight: Int = 0

    init {
        Lg.e("init")
        mScreenWidth = ScreenUtil.getScreenWidth(context).toInt()
    }

    public fun setWidth(width: Int) {
        mFixWidth = width
    }

    public fun setHeight(height: Int) {
        mFixHeight = height
    }

    public fun loadUrl(url: String, @DrawableRes placeholder: Int, action: String?) {
        try {
            setOnClickListener { Routers.open(context, action) }
        } catch (e: Exception) {
            Lg.e(e)
        }

        if (mFixHeight == 0 && mFixWidth == 0) {
            Glide.with(context).load(url).crossFade().placeholder(placeholder).diskCacheStrategy(DiskCacheStrategy.SOURCE).into(this)
            return
        }
        var drawableHeight: Int = 0
        var drawableWidth: Int = 0
        var viewHeight: Int = 0
        var viewWidth: Int = 0


        Glide.with(context).load(url).into(object : SimpleTarget<GlideDrawable>(viewWidth, viewHeight) {
            override fun onResourceReady(resource: GlideDrawable?, glideAnimation: GlideAnimation<in GlideDrawable>?) {

                drawableHeight = resource!!.intrinsicHeight
                drawableWidth = resource.intrinsicWidth
                if (mFixWidth > 0) {
                    viewWidth = mFixWidth;
                    viewHeight = (drawableHeight * viewWidth) / drawableWidth
                }
                if (mFixHeight > 0) {
                    viewHeight = mFixHeight;
                    viewWidth = (drawableWidth * viewHeight) / drawableHeight
                }
                Lg.e("drawableHeight:$drawableHeight")
                Lg.e("drawableWidth:$drawableWidth")
                Lg.e("viewHeight:$viewHeight")
                Lg.e("viewWidth:$viewWidth")

                layoutParams = ViewGroup.LayoutParams(viewWidth, viewHeight)
                setImageDrawable(resource)

            }
        })
    }
}

简单举了几个例子,当然还有其他工具库,比如Anko等的使用,后面又用到的话也会分享出来,更多Kotlin的细节可以上Kotlin社区了解。

如果有什么说得不对的地方,就不要评论了,(开玩笑)。(╯‵□′)╯︵┻━┻

timg.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,398评论 25 707
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,680评论 2 59
  • 前言 人生苦多,快来 Kotlin ,快速学习Kotlin! 什么是Kotlin? Kotlin 是种静态类型编程...
    任半生嚣狂阅读 26,139评论 9 118
  • 在生活中我们最常说的一句话就是:三思而后行,但是有时候想的太多,却未必有利于行动。有时候改变了自己的行动,自己的想...
    好听的暖阳阅读 437评论 2 4
  • AFNetWorking 的学习,主要以实际使用过程来看里面源码具体做了什么事。 从上面来看,主要是三个过程: 初...
    Aliyunyun阅读 2,280评论 5 7