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

 更新时间:2017年05月19日 09:55:40   作者:Xuejianxin_  
这篇文章主要介绍了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()的正确打开方式

    这篇文章主要给大家介绍了关于Android中LayoutInflater.inflater()的正确打开方式,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-12-12
  • android RadioGroup的使用方法

    android RadioGroup的使用方法

    android RadioGroup的使用方法,需要的朋友可以参考下
    2012-11-11
  • kotlin实现语音聊天机器人案例详解

    kotlin实现语音聊天机器人案例详解

    Android智能问答机器人是时下非常流行的一种服务,微软“小冰”的出现更是让其实实在在的风靡了一把。那么,本文章就将带领大家完整的实现整个问答机器人的制作
    2023-02-02
  • Android编程实现两个Activity相互切换而不使用onCreate()的方法

    Android编程实现两个Activity相互切换而不使用onCreate()的方法

    这篇文章主要介绍了Android编程实现两个Activity相互切换而不使用onCreate()的方法,结合实例形式分析了多个Activity切换而不重新创建的操作技巧,需要的朋友可以参考下
    2017-01-01
  • 非常实用的小功能 Android应用版本的更新实例

    非常实用的小功能 Android应用版本的更新实例

    这篇文章主要为大家详细介绍了一个非常实用的小功能,Android应用版本的更新实例,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • 自定义View之kotlin绘制折线图实例教程

    自定义View之kotlin绘制折线图实例教程

    折线图是我们在开发中经常会遇到的一个需求,下面这篇文章主要给大家介绍了关于自定义View之kotlin绘制折线图的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-09-09
  • Android生成条形码和二维码功能

    Android生成条形码和二维码功能

    随着移动互联网的普及以及智能终端设备的广泛应用,移动支付变得越来越便捷,通过扫描二维码代替传统的刷卡行为。这篇文章给大家介绍Android生成条形码和二维码功能,需要的朋友参考下吧
    2019-10-10
  • Android数据库增删改查实战案例

    Android数据库增删改查实战案例

    我们在编程中经常会遇到数据库的操作,这篇文章主要给大家介绍了关于Android数据库增删改查的相关资料,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • Android自定义圆弧进度条加数字动态变化

    Android自定义圆弧进度条加数字动态变化

    这篇文章主要为大家详细介绍了Android自定义圆弧进度条加数字动态变化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • 解决Android Studio 3.0 butterknife:7.0.1配置的问题

    解决Android Studio 3.0 butterknife:7.0.1配置的问题

    下面小编就为大家分享一篇解决Android Studio 3.0 butterknife:7.0.1配置的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12

最新评论