kotlin 官方学习教程之基础语法详解
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 官网运行一下代码,结合本文自行理解。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
相关文章
Android中LayoutInflater.inflater()的正确打开方式
这篇文章主要给大家介绍了关于Android中LayoutInflater.inflater()的正确打开方式,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧2018-12-12Android编程实现两个Activity相互切换而不使用onCreate()的方法
这篇文章主要介绍了Android编程实现两个Activity相互切换而不使用onCreate()的方法,结合实例形式分析了多个Activity切换而不重新创建的操作技巧,需要的朋友可以参考下2017-01-01解决Android Studio 3.0 butterknife:7.0.1配置的问题
下面小编就为大家分享一篇解决Android Studio 3.0 butterknife:7.0.1配置的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2017-12-12
最新评论