温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

kotlin 官方学习教程之基础语法详解

发布时间:2020-10-23 06:38:26 来源:脚本之家 阅读:192 作者:Xuejianxin_ 栏目:移动开发

kotlin 官方学习教程之基础语法详解

Google 在今天的举行了 I/O 大会,大会主要主要展示内有容 Android O(Android 8.0)系统、Google Assistant 语音助手、Google 智能音箱、人工智能、机器学习、虚拟现实等。作为一个 Android 开发者,我关心的当然是 Android O(Android 8.0)系统了,那么关于 Android O 系统的一个重要消息是全面支持 Kotlin 编程语言,使得 Kotlin 成为了 Android 开发的官方语言,被称为 Android 开发中的 Swift 的它有什么优势,又到底会为 Android 开发者带来什么,还需要时间来观察。但是作为开发者的我们,已经可以明确的知道 Kotlin 是接下来 Android 开发的官方语言,所以,今天就为大家翻译一下 kotlin 官方文档。

基础语法

定义包名

包名应该在源文件的顶部定义:

 package my.demo import java.util.* // ... 

定义函数

带有两个 Int 型参数和 Int 返回类型的函数

 fun sum(a: Int, b: Int): Int { return a + b } fun main(args: Array<String>) { print("sum of 3 and 5 is ") println(sum(3, 5)) } 

带有具体表达式并可以推测返回类型的函数

 fun sum(a: Int, b: Int) = a + b fun main(args: Array<String>) { println("sum of 19 and 23 is ${sum(19, 23)}") } 

返回无意义值的函数

 fun printSum(a: Int, b: Int): Unit { println("sum of $a and $b is ${a + b}") } fun main(args: Array<String>) { printSum(-1, 8) } 

Unit 返回类型的函数返回类型可以省略

 fun printSum(a: Int, b: Int) { println("sum of $a and $b is ${a + b}") } fun main(args: Array<String>) { printSum(-1, 8) } 

定义局部变量

赋值一次(只读)局部变量

 fun main(args: Array<String>) { val a: Int = 1 // 定义变量时进行赋值 val b = 2 // 自动推测变量类型为 Int val c: Int // 不提供初始化时需要定义变量类型 c = 3 // 定义变量后再赋值 println("a = $a, b = $b, c = $c") } 

可变的变量

 fun main(args: Array<String>) { var x = 5 // 推断变量类型为 Int x += 1 println("x = $x") } 

注释

 像 Java 和 JavaScript 一样,Kotlin 支持行注释和块注释。 // 这是行注释 /* 这是 块注释 */ 

和 java 不同的是,Kotlin 块注释可以嵌套。

使用字符串模板

 fun main(args: Array<String>) { var a = 1 // 使用变量名作为模板: val s1 = "a is $a" a = 2 // 使用任意表达式作为模板: val s2 = "${s1.replace("is", "was")}, but now is $a" println(s2) } 

使用条件表达式

 fun maxOf(a: Int, b: Int): Int { if (a > b) { return a } else { return b } } fun main(args: Array<String>) { println("max of 0 and 42 is ${maxOf(0, 42)}") } 

以 if 作为表达式

 fun maxOf(a: Int, b: Int) = if (a > b) a else b fun main(args: Array<String>) { println("max of 0 and 42 is ${maxOf(0, 42)}") } 

使用可空变量以及空值检查

可能出现空值时,引用必须明确标记为可空的。

 返回 NULL 如果 STR 不持有整数 fun parseInt(str: String): Int? { // ... } 

使用一个函数返回空值

 fun parseInt(str: String): Int? { return str.toIntOrNull() } fun printProduct(arg1: String, arg2: String) { val x = parseInt(arg1) val y = parseInt(arg2) // 使" X×Y "产生错误的因为他们可能有空值。 if (x != null && y != null) { // 经过空值检测后,X 和 Y 自动转换为非空值。 println(x * y) } else { println("either '$arg1' or '$arg2' is not a number") } } fun main(args: Array<String>) { printProduct("6", "7") printProduct("a", "7") printProduct("a", "b") } 

又或者这个函数

 fun parseInt(str: String): Int? { return str.toIntOrNull() } fun printProduct(arg1: String, arg2: String) { val x = parseInt(arg1) val y = parseInt(arg2) // ... if (x == null) { println("Wrong number format in arg1: '${arg1}'") return } if (y == null) { println("Wrong number format in arg2: '${arg2}'") return } // 经过空值检测后,X 和 Y 自动转换为非空值。 println(x * y) } fun main(args: Array<String>) { printProduct("6", "7") printProduct("a", "7") printProduct("99", "b") } 

使用类型检查和自动转换

is 操作符检查表达式是否为某个类型实例。如果对不可变局部的变量或属性进行特定类型检查了,就不需要明确的类型转换:

 fun getStringLength(obj: Any): Int? { if (obj is String) { // obj 将会在这个分支被自动转换为 String 类型 return obj.length } // obj 在种类检查外仍然是 Any 类型 return null } fun main(args: Array<String>) { fun printLength(obj: Any) { println("'$obj' string length is ${getStringLength(obj) ?: "... err, not a string"} ") } printLength("Incomprehensibilities") printLength(1000) printLength(listOf(Any())) } 

又或者这个函数

 fun getStringLength(obj: Any): Int? { if (obj !is String) return null // obj 将会在这个分支被自动转换为 String 类型 return obj.length } fun main(args: Array<String>) { fun printLength(obj: Any) { println("'$obj' string length is ${getStringLength(obj) ?: "... err, not a string"} ") } printLength("Incomprehensibilities") printLength(1000) printLength(listOf(Any())) } 

又或者是这个函数

 fun getStringLength(obj: Any): Int? { // // obj 将会在 && 右边被自动转换为 String 类型 if (obj is String && obj.length > 0) { return obj.length } return null } fun main(args: Array<String>) { fun printLength(obj: Any) { println("'$obj' string length is ${getStringLength(obj) ?: "... err, is empty or not a string at all"} ") } printLength("Incomprehensibilities") printLength("") printLength(1000) } 

使用 for 循环

 fun main(args: Array<String>) { val items = listOf("apple", "banana", "kiwi") for (item in items) { println(item) } } 

又或者这样写

 fun main(args: Array<String>) { val items = listOf("apple", "banana", "kiwi") for (index in items.indices) { println("item at $index is ${items[index]}") } } 

使用 while 循环

 fun main(args: Array<String>) { val items = listOf("apple", "banana", "kiwi") var index = 0 while (index < items.size) { println("item at $index is ${items[index]}") index++ } } 

使用 when 表达式

 fun describe(obj: Any): String = when (obj) { 1 -> "One" "Hello" -> "Greeting" is Long -> "Long" !is String -> "Not a string" else -> "Unknown" } fun main(args: Array<String>) { println(describe(1)) println(describe("Hello")) println(describe(1000L)) println(describe(2)) println(describe("other")) } 

使用 ranges

检查 in 操作符检查数值是否在某个范围内:

 fun main(args: Array<String>) { val x = 10 val y = 9 if (x in 1..y+1) { println("fits in range") } } 

检查一个数值是否超出范围

 fun main(args: Array<String>) { val list = listOf("a", "b", "c") if (-1 !in 0..list.lastIndex) { println("-1 is out of range") } if (list.size !in list.indices) { println("list size is out of valid list indices range too") } } 

在范围内范围迭代:

 for (x in 1..5) { print(x) } 

或者使用步进:

 for (x in 1..10 step 2) { print(x) } for (x in 9 downTo 0 step 3) { print(x) } 

使用集合

对一个集合进行迭代:

 for (item in items) { println(item) } 

使用 in 操作符检查集合中是否包含某个对象

 when { "orange" in items -> println("juicy") "apple" in items -> println("apple is fine too") } 

使用 lambda 表达式筛选和映射集合

 fruits .filter { it.startsWith("a") } .sortedBy { it } .map { it.toUpperCase() } .forEach { println(it) } 

难以理解的小伙伴可以到 kotlin 官网运行一下代码,结合本文自行理解。

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI