一.Kotlin调用java
1.调用java可空属性
????????Java世界里所有对象都可能是nu当一个Kotlin函数返回String类型值,你不能想当然地认为它的返回值就能符合Kotlin关于空值的规定。
fun main() {
val jhava = Jhava()
//平台类型
val nullss = jhava.nullss
val stringss = jhava.strings
//这里用了java的属性,因为java属性随时可空,所以要加非空操作符
print("${nullss?.length} \n")
}
public class Jhava {
@NonNull
public String getStrings(){
return "Hello";
}
@Nullable
public String getNull(){
return null;
}
}
2.查看调用java属性的类型
? ? ? ? 代码运行时,所有的映射类型都会重写映射回对应的java类型。
fun main() {
val jhava = Jhava()
//平台类型
val stringss = jhava.strings
print("${nullss?.length} \n")
//打印所调用的类型
print(stringss?.length.javaClass)
print(stringss?.length.dec())
}
3.调用java属性并赋值
? ? ? ? 不需要调用setter方法,你可以使用赋值语法来设置一个java字段值了。
fun main() {
val jhava = Jhava()
//调用java 的set
jhava.str = "#213123"
}
public class Jhava {
private String str="!111";
}
二.java调用kotlin
1.@JvmName
? ? ? ? 使用@jvmName注解指定编译类的名字。
//放到包名上面
@file:JvmName("JKotlin")
package com.example.kotiln_a
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
//用修改后的类名调用
String make =JKotlin.make();
}
}
2.@JvmField
????????在Java里,不能直接访问lsit?字段,所以必须调用getlsit?,然而,你可以给Kotlin属性添加@JvmFieId注解,暴露它的支持字段给java调用者,从而避免使用getter方法。
@JvmField //java 可以以静态的方式调用本属性
val lsit = listOf("3123", "32134124124", "12412")
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
//直接调用Kotlin的字段
List<String> lsit = JKotlin.lsit;
}
3.JvmOverloads
????????@JvmOverloads注解协助产生Kotlin函数的重载版本。设计一个可能会暴露给java用户使用的API时,记得使用@JvmOverloads注解,这样,无论你是Kotlin开发者还是java开发者,都会对这个AP|的可靠性感到满意。
@JvmOverloads //java 调用本方法可自动重载
fun handOverFood(leftHand: String = "be", RightHand: String = "ft") {
print("$leftHand #$RightHand")
}
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
JKotlin.handOverFood("apple");
}
}
4.@JvmStatic
? ? ? ? @JvmField注解还能用来以静态方式提供伴生对象里定义的值。
? ? ? ? @JvmStatic注解的作用类似于@JvmField,允许你直接调用伴生对象里的函数
class JKotlin2 {
companion object{
@JvmField
val MAX_LEVET=10
@JvmStatic
fun getSpe()= print("i am the Great Grimoire!")
}
}
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
//不加JvmField调法
// int max_levet = JKotlin2.Companion.getMAX_LEVET();
//加注解后的调法
int max_levet = JKotlin2.MAX_LEVET;
JKotlin2.getSpe();
}
}
5.@Throws
????????抛出一个需要检查的指定异常,Java和Kotlin有关异常检查的差异让@Throws注解给解决掉了,在编写供」ava开发者调用的KotIinAPI时,要考虑使用@Throws注解,这样,用户就知道怎么正确处理任何异常了。
//java调 Kotlin抛异常
@Throws(IOException::class)
fun acceptApology() {
throw IOException()
}
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
try {
JKotlin.acceptApology();
} catch (IOException e) {
e.printStackTrace();
}
}
}
?
6.函数式操作
val translatot={
utterance:String-> println(utterance.toLowerCase().capitalize())
}
public class Jhava {
//调用的Kotlin
public static void main(String[] args) {
Function1<String, Unit> translatot = JKotlin.getTranslatot();
translatot.invoke("TRUCE");
}
}
|