您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)kotlin語(yǔ)法特性有哪些的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
Google I/O 2017 開(kāi)發(fā)者大會(huì)中,Google 宣布正式把 Kotlin 納入 Android 程序的官方一級(jí)開(kāi)發(fā)語(yǔ)言(First-class language),作為Android開(kāi)發(fā)者,當(dāng)然要逐步熟悉這門(mén)語(yǔ)言,第一步就要從語(yǔ)法開(kāi)始學(xué)習(xí)。
在這之前,我們需要了解怎么使用Kotlin編寫(xiě)一個(gè)Android應(yīng)用。對(duì)于Android Studio 3.0版本,我們?cè)趧?chuàng)建工程的時(shí)候直接勾選 Include Kotlin support 選項(xiàng)就可以了;對(duì)于3.0以前的版本,我們需要安裝Kotlin插件,同時(shí)還要手動(dòng)配置gradle,方法如下
在app的gradle下加入如下代碼
apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions'
在project的gradle下加入如下代碼
ext.kotlin_version = '1.1.2-3' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
Kotlin定義變量
kotlin 里的變量定義有兩種,val 和 var,其中 val 等同 Java 中 final 修飾的變量(只讀),一般是常量,var一般是變量。
kotlin 的變量定義支持賦值時(shí)類(lèi)型推斷,且所有變量默認(rèn)被修飾為「不可為 null」,必須顯式在類(lèi)型后添加 ? 修飾符才可賦值為 null。
我們寫(xiě)代碼時(shí)要盡量習(xí)慣性地將變量設(shè)計(jì)為不可為空,這樣在后面對(duì)該變量的運(yùn)算中會(huì)減少很多問(wèn)題。
Kotlin函數(shù)擴(kuò)展
具體的語(yǔ)法是fun + 類(lèi)型.函數(shù)(參數(shù))
fun Context.toast(message: String, length: Int = Toast.LENGTH_SHORT) { Toast.makeText(this, message, length).show() }
Kotlin Parcelable序列化
package com.john.kotlinstudy import android.os.Parcel import android.os.Parcelable /** * Java Bean 數(shù)據(jù)實(shí)體類(lèi) * Created by john on 17-5-24. */ data class UserBean(var name: String, var id: String) : Parcelable { constructor(source: Parcel) : this(source.readString(), source.readString()) override fun describeContents(): Int { return 0 } override fun writeToParcel(dest: Parcel, flags: Int) { dest.writeString(this.name) dest.writeString(this.id) } companion object { @JvmField val CREATOR: Parcelable.Creator<UserBean> = object : Parcelable.Creator<UserBean> { override fun createFromParcel(source: Parcel): UserBean { return UserBean(source) } override fun newArray(size: Int): Array<UserBean?> { return arrayOfNulls(size) } } } }
companion關(guān)鍵字解讀
不像 Java 或者 C#,在 Kotlin 中,Class 沒(méi)有靜態(tài)方法,在大多數(shù)情況下,推薦用 package-level 的函數(shù)來(lái)代替靜態(tài)方法。
如果你需要寫(xiě)一個(gè)不需要實(shí)例化 Class 就能訪問(wèn) Class 內(nèi)部的函數(shù)(例如一個(gè)工廠函數(shù)),你可以把它聲明成 Class 內(nèi)的一個(gè)實(shí)名 Object。
另外,如果你在 Class 內(nèi)聲明了一個(gè) companion object,在該對(duì)象內(nèi)的所有成員都將相當(dāng)于使用了 Java/C# 語(yǔ)法中的 static 修飾符,在外部只能通過(guò)類(lèi)名來(lái)對(duì)這些屬性或者函數(shù)進(jìn)行訪問(wèn)。
@JvmField 注解作用
指示Kotlin編譯器不為此屬性生成getter / setter,并將其作為一個(gè)字段暴露出來(lái)。
如果您需要在Java中公開(kāi)Kotlin屬性作為字段,則需要使用@JvmField注釋對(duì)其進(jìn)行注釋,該字段將具有與底層屬性相同的可見(jiàn)性。
Kotlin 編寫(xiě)工具類(lèi)
在Java中,我們會(huì)將一些常用的功能封裝成一個(gè)個(gè)工具類(lèi),工具類(lèi)其實(shí)就是對(duì)于String,Collection,IO 等常用類(lèi)的功能的擴(kuò)展。我們寫(xiě)的工具類(lèi)方法和變量都會(huì)寫(xiě)成靜態(tài)的。因?yàn)?,這些方法我們只是想調(diào)用一下,不需要牽扯工具類(lèi)中的任何屬性和變量,所以就沒(méi)有必要實(shí)例化了(new),既然不需要實(shí)例化了,那么就用靜態(tài)就行了。
package com.john.kotlinstudy import android.content.Context import android.widget.Toast /** * Toast工具類(lèi) * Created by john on 17-5-24. */ object ToastUtils { fun toast(context: Context, message: String) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show() } }
Kotlin Activity 跳轉(zhuǎn)
我們?cè)贛ainActivity設(shè)置點(diǎn)擊事件,跳轉(zhuǎn)到另一個(gè)Activity,同時(shí)傳遞數(shù)據(jù)過(guò)去
package com.john.kotlinstudy import android.content.Context import android.support.v7.app.AppCompatActivity import android.os.Bundle import android.widget.Toast import kotlinx.android.synthetic.main.activity_main.* class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) test_tv.text = "hello kotlin" test_tv.setOnClickListener { ToastUtils.toast(this, "hello kotlin") val user = UserBean("zhang", "001") user.id = "100" SecondActivity.navigateTo(this, user) } } fun Context.toast(message: String, length: Int = Toast.LENGTH_SHORT) { Toast.makeText(this, message, length).show() } }
然后新建一個(gè)SecondActivity,提供一個(gè)靜態(tài)方法,用于Activity的跳轉(zhuǎn)。想必大家都知道這樣做的好處,就是讓調(diào)用者不必看源碼就知道需要什么參數(shù)。如果你按照java寫(xiě),就會(huì)發(fā)現(xiàn)沒(méi)有static這個(gè)關(guān)鍵字!不要慌,這里可以使用伴生對(duì)象來(lái)實(shí)現(xiàn),伴生對(duì)象是伴隨這個(gè)類(lèi)聲明周期的對(duì)象。
package com.john.kotlinstudy import android.content.Context import android.content.Intent import android.os.Bundle import android.support.v7.app.AppCompatActivity import kotlinx.android.synthetic.main.activity_second.* /** * 跳轉(zhuǎn)Activity測(cè)試類(lèi) * Created by john on 17-5-24. */ class SecondActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_second) val user = intent.getParcelableExtra<UserBean>(EXTRA_KEY_USER) user_name_tv.text = user.name ToastUtils.toast(this, user.id) } //創(chuàng)建一個(gè)伴生對(duì)象 companion object { //extra的key val EXTRA_KEY_USER = "extra.user" fun navigateTo(context: Context, user: UserBean) { val intent = Intent(context, SecondActivity::class.java) intent.putExtra(EXTRA_KEY_USER, user) context.startActivity(intent) } } }
感謝各位的閱讀!關(guān)于“kotlin語(yǔ)法特性有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。