当前位置: 首页 > 编程笔记 >

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

子车青青
2023-03-14
本文向大家介绍kotlin 官方学习教程之基础语法详解,包括了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 官网运行一下代码,结合本文自行理解。

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

 类似资料:
  • 本文向大家介绍seajs学习教程之基础篇,包括了seajs学习教程之基础篇的使用技巧和注意事项,需要的朋友参考一下 介绍 众所周知前端开发模块化已经是大势所趋,目前模块化的规范有很多,众所周知的有commonJS,Module/Wrappings和AMD等,而且ES6也着手开始制定模块化机制的实现。类似于c/c++的include,java中的import关键字,在js中也定义了require关键

  • 本文向大家介绍Ruby的基础语法入门学习教程,包括了Ruby的基础语法入门学习教程的使用技巧和注意事项,需要的朋友参考一下 让我们编写一个简单的 Ruby 程序。所有的 Ruby 文件扩展名都是 .rb。所以,把下面的源代码放在 test.rb 文件中。 实例 在这里,假设您的 /usr/bin 目录下已经有可用的 Ruby 解释器。现在,尝试运行这个程序,如下所示: 这将会产生下面的结果: 您已

  • 本文向大家介绍Three.js基础学习教程,包括了Three.js基础学习教程的使用技巧和注意事项,需要的朋友参考一下 一、Three.js官网及使用Three.js必备的三个条件 1.Three.js 官网 https://threejs.org/ 2.使用Three.js必备的三个条件 (To actually be able to display anything with Three.js

  • 本文向大家介绍Django学习笔记之ORM基础教程,包括了Django学习笔记之ORM基础教程的使用技巧和注意事项,需要的朋友参考一下 ORM简介 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据

  • 本文向大家介绍socket.io学习教程之基础介绍(一),包括了socket.io学习教程之基础介绍(一)的使用技巧和注意事项,需要的朋友参考一下 前言 Web端与服务器间的实时数据传输的是一个很重要的需求,但最早只能通过AJAX轮询询实现。在WebSocket标准没有推出之前,AJAX轮询是唯一可行的方式(通过Flash浏览器也可以,但这里不做讨论)。AJAX轮询原理是设置定时器,定时通过AJA

  • 本文向大家介绍JavaScript学习笔记之基础语法,包括了JavaScript学习笔记之基础语法的使用技巧和注意事项,需要的朋友参考一下 JavaScript中很多基础内容和Java中大体上基本一样,所以不需要再单独重复讲了,包括:   各种算术运算符、比较运算符、逻辑运算符;   if else语句、switch语句;   for循环、while循环、do while循环;   标签、brea