Java與Kotlin怎么實(shí)現(xiàn)交互,針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
創(chuàng)新互聯(lián)公司于2013年創(chuàng)立,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元揭東做網(wǎng)站,已為上家服務(wù),為揭東各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220kotlin調(diào)用java
可空性(Nullability)
Java默認(rèn)有數(shù)值可空性而kotlin沒(méi)有,所以在調(diào)用Java的方法的時(shí)候不知道會(huì)不會(huì)收到空值。所以我們?cè)贙otlin中調(diào)用Java的時(shí)候需要添加 ?或者 !來(lái)告訴Kotlin有可能出現(xiàn)空值。
比如這里有一個(gè)Java方法,接受一組字符串后返回一組做字符串:
public Set<String> toSet(Collection<String> elements){ //TODO}
那么Kotlin在調(diào)用的時(shí)候是不能確定輸入和輸出是否可為空的。就需要使用?或者 !來(lái)輔助判斷。
為了方便Kotlin調(diào)用,我們通常使用 @NotNull 注解來(lái)標(biāo)識(shí)Java代碼的非原始參數(shù)、字段、返回值。
@NotNullSet<@NotNull String> toSet(@NotNull Collection<@NotNull String> elements){ //TODO}
這個(gè)Kotlin在調(diào)用的時(shí)候就明確知道不能為空,這里我們使用的是jetBrain的 @NotNull注解,當(dāng)然還有其他選擇,如下圖:
這里還是推薦使用JetBrain或者Android的注解。
前綴屬性:(getter、setter)
如果是使用Java bean,那么我們?cè)贙otlin中調(diào)用就沒(méi)有什么問(wèn)題。
如果你的空參數(shù)方法是以get開(kāi)頭的,那么Kotlin就知道這是getter,就可以通過(guò)屬性名來(lái)訪問(wèn)它。
相同的如果是由set開(kāi)頭的單一參數(shù)方法,那么Kotlin就知道這是setter,就通過(guò)屬性名直接賦值。
當(dāng)然is的工作原理也是和它們類(lèi)似的。
我們定義一個(gè)Java bean:
class User { private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; }}
Kotlin中訪問(wèn)
val user = User()user.name = "四爺" //賦值val age = user.age //獲取age字段值
關(guān)鍵字(keywords)
kotlin中有很多系統(tǒng)定義的關(guān)鍵字如 fun is in objects、typeof、val、var、when、typealias等。
這些關(guān)鍵字在java是可以被使用的,但是在kotlin卻是不行的。
函數(shù)或者參數(shù)使用了這些關(guān)鍵字,那么kotlin在調(diào)用的時(shí)候會(huì)出現(xiàn)一些問(wèn)題,比如Java中定義了一個(gè)方法名叫 is 的方法。那么在Kotlin中直接調(diào)用就會(huì)報(bào)錯(cuò)。
那么最簡(jiǎn)單的方法就是重命名Java方法,但如果調(diào)用的是三方庫(kù)的方法,就很難去重命名了。所以我們另一種解決方式是在Kotlin調(diào)用java方法的時(shí)候加上 `` 反引號(hào)來(lái)使用。
Utils.`is`()
但是我們?nèi)绻苤孛€是重命名,以防止代碼出現(xiàn)太多的符號(hào)。
避免在任何擴(kuò)展方法和擴(kuò)展屬性上使用Any
運(yùn)算符重載(operator Overloading)
在Java不存在運(yùn)算符重載,而kotlin有。比如:
a+b => a.plus(b)
在kotlin中將運(yùn)算符 + 翻譯為了方法 plus。
如果在Java中使用了同樣的方法名稱,比如 加(plus)、 減(minus)或者其他運(yùn)算符名稱,那么請(qǐng)務(wù)必確保他們與運(yùn)算符兼容,避免意外調(diào)用他們。
Java調(diào)用Kotlin
JvmName & JvmMultifileClass
當(dāng)我們?cè)谶w移的時(shí)候會(huì)將Java的工具類(lèi)翻譯為Kotlin拓展函數(shù)或者頂層函數(shù)。但是這樣處理之后,在Java文件中是無(wú)法直接調(diào)用的,此時(shí)我們需要加注解 @file:JvmName(“文件名稱”):
Ext.kt文件
@file:JvmName("ExtUtils")package com.demo.javaAndKotlinfun a(): String { ...}fun b(): String { ...}
這里我們將名稱命名為ExtUtils。此外,我們可能還有其他的頂層函數(shù)或者擴(kuò)展函數(shù)。按照上面這種方式我們也可以指定一個(gè)其他的名稱,但是如果我們也想使用ExtUtils這個(gè)名稱的時(shí)候會(huì)報(bào)錯(cuò):
Duplicate JVM class name
此時(shí)我們需要在不同的文件中加入新的注解 @file:JvmMultifileClass 。意思是將所有的文件合并到一個(gè)新的名稱為ExtUtils文件中。
ExtOther.kt文件
@file:JvmMultifileClass@file:JvmName("ExtUtils")package com.demo.javaAndKotlinfun c(str: Any): String { ...}
我們?cè)贓xt.kt文件中也加入@file:JvmMultifileClass注解,我們就可以在Java文件中直接使用ExtUtils來(lái)調(diào)用 a(),b(),c()方法了。
JvmField
在 kotlin中我們使用的數(shù)據(jù)類(lèi)即 data class 是不需要指定getter和setter的,可以直接通過(guò)字段名來(lái)訪問(wèn)它們。但是如果是在Java文件中調(diào)用data class依舊是需要使用getter和setter方法進(jìn)行調(diào)用的。這里我們是可以修改他們的,那就是使用 @JvmField 注解,通過(guò)注解,可以直接將字段暴露出去進(jìn)行訪問(wèn)。
data class Person( @JvmField var name: String, @JvmField var age: Int)//java中調(diào)用Person person = new Person("",1);person.name = "";person.age = 10;
但是也有例外就是lateinit修飾的字段會(huì)自動(dòng)暴露,無(wú)需指定@JvmField注解。還有const修飾的字段也是一樣會(huì)自動(dòng)暴露。
另外,如果我們想在Java中調(diào)用setName的時(shí)候修改這個(gè)屬性名稱不叫setName,這里我們需要使用@set:JvmName 注解。同理修改getName使用@get:JvmName 。需要注意的是,指定了@set:JvmName或者@get:JvmName注解后不需要在指定@JvmField了。
data class Person( @set:JvmName("changeName") var name: String, @JvmField var age: Int, @get:JvmName("likesPink") var likesPink: Boolean){ lateinit var address:String}
JvmStatic
當(dāng)我們將Java文件的靜態(tài)方法遷移到Kotlin中時(shí),我們會(huì)將其放在 companion object中,但是這樣處理之后在Java文件中無(wú)法直接調(diào)用,得通過(guò)companion對(duì)象實(shí)例方法來(lái)調(diào)用。
class MyService { internal fun doWork() { ... } companion object { fun schedule(context: Context) { ... } }}//在Java中調(diào)用MyService.Companion.schedule(this);
幸運(yùn)的是Kotlin提供了 @JvmStatic 注解。他會(huì)讓Kotlin在編譯器完成類(lèi)封裝后生成一個(gè)靜態(tài)方法。
class MyService { internal fun doWork() { ... } companion object { @JvmStatic fun schedule(context: Context) { ... } }}//在Java中調(diào)用MyService.schedule(this);
JvmOverloads
在Kotlin中我們可以給函數(shù)的參數(shù)設(shè)置默認(rèn)值,即默認(rèn)參數(shù)。但是這個(gè)功能在Java中是沒(méi)有的。如果不做任何處理,那么在Java中調(diào)用函數(shù)的時(shí)候,就必須每個(gè)參數(shù)都要傳入。那么我們?cè)O(shè)置的默認(rèn)參數(shù)就沒(méi)有任何意義了。
所以,Kotlin給我們提供了 @JvmOverloads注解,使用這個(gè)注解后,會(huì)讓Kotlin編譯器按照從左向右的順序依次為每一個(gè)可選參數(shù)生成重載。
@JvmOverloadsfun Bitmap.resize(width: Int, height: Int = 200) {}//java調(diào)用ExtUtils.resize(bitmap,100);
這里我們?cè)贙otlin中很容易就理解了Bitmap.resize方法的含義,但是ExtUtils.resize這樣調(diào)用的時(shí)候,方法名不夠明確。所以我們可以使用@JvmName注解來(lái)指定名稱。
@JvmName("resizeBitmap")@JvmOverloadsfun Bitmap.resize(width: Int, height: Int = 200) {}//java調(diào)用ExtUtils.resizeBitmap(bitmap,100);
關(guān)于Java與Kotlin怎么實(shí)現(xiàn)交互問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
文章標(biāo)題:Java與Kotlin怎么實(shí)現(xiàn)交互-創(chuàng)新互聯(lián)
文章來(lái)源:http://aaarwkj.com/article48/hcihp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、小程序開(kāi)發(fā)、定制開(kāi)發(fā)、云服務(wù)器、域名注冊(cè)、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容