Kotlin 变量

变量是用于存储数据值的容器。

要创建一个变量,使用 varval,然后使用等号(=)给它赋值:

语法

var 变量名 = 值
val 变量名 = 值

示例

var name = "John"
val birthyear = 1975 println(name) // 打印 name 的值
println(birthyear) // 打印 birthyear 的值

varval 的区别在于使用 var 关键字声明的变量可以被更改/修改,而 val 变量则不行。

变量类型

与许多其他编程语言不同,Kotlin 中的变量不需要声明指定的类型(比如对于文本是 "String",对于数字是 "Int",如果你熟悉的话)。

要在 Kotlin 中创建一个应该存储文本的变量和另一个应该存储数字的变量,请看下面的示例:

示例

var name = "John"      // String(文本)
val birthyear = 1975 // Int(数字) println(name) // 打印 name 的值
println(birthyear) // 打印 birthyear 的值

Kotlin 足够智能,可以理解 "John" 是一个 String(文本),而 1975 是一个 Int(数字)变量。

然而,如果你坚持的话,也可以指定类型:

示例

var name: String = "John" // String
val birthyear: Int = 1975 // Int println(name)
println(birthyear)

你也可以在不分配值的情况下声明一个变量,并在以后分配值。但是,这只有在指定类型时才可能:

示例

这样是可以的:

var name: String
name = "John"
println(name)

示例

这将生成一个错误:

var name
name = "John"
println(name)

注意:你将在下一章学习更多关于数据类型的知识。

关于 val 的注意事项

当你使用 val 关键字创建一个变量时,值不能被更改/重新分配。

以下示例将生成一个错误:

示例

val name = "John"
name = "Robert" // 错误(val 不能重新赋值)
println(name)

当使用 var 时,你可以随时更改值:

示例

var name = "John"
name = "Robert"
println(name)

那么何时使用 val

当你希望一个变量始终存储相同的值时,val 关键字是有用的,比如 PI(3.14159...):

示例

val pi = 3.14159265359
println(pi)

显示变量

就像你在上面的示例中看到的那样,println() 方法经常用于显示变量。

要同时结合文本和变量,使用 + 字符:

示例

val name = "John"
println("你好 " + name)

你也可以使用 + 字符将一个变量添加到另一个变量:

示例

val firstName = "John "
val lastName = "Doe"
val fullName = firstName + lastName
println(fullName)

对于数值,+ 字符作为数学运算符:

示例

val x = 5
val y = 6
println(x + y) // 打印 x + y 的值

从上面的示例中,你可以预期:

x 存储值 5

y 存储值 6

然后我们使用 println() 方法来显示 x + y 的值,即 11

变量名

一个变量可以有一个简短的名称(比如 x 和 y)或更具描述性的名称(age、sum、totalVolume)。

Kotlin 变量的一般规则是:

  • 名称可以包含字母、数字、下划线和美元符号
  • 名称应该以字母开头
  • 名称也可以以 $ 和 _ 开头(但我们在本教程中不会使用)
  • 名称区分大小写("myVar" 和 "myvar" 是不同的变量)
  • 名称应该以小写字母开头,不能包含空格
  • 保留字(比如 Kotlin 关键字,如 var 或 String)不能用作名称

驼峰命名法变量

你可能注意到我们在上面的示例中使用了 firstName 和 lastName 作为变量名称,而不是 firstname 和 lastname。这被称为 "驼峰命名法",被认为是一个良好的实践,因为当你有一个变量名中包含不同单词时,比如 "myFavoriteFood"、"rateActionMovies" 等,这样做可以使它更易读。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

Kotlin 变量详解:声明、赋值与最佳实践指南的更多相关文章

  1. Java面向对象之各种变量详解

    在Java中一定有很多变量让大家头疼,成员变量.类变量.局部变量等等,今天就来分别认识认识他们吧! Java面向对象之各种变量详解 前言 在 Java语言中, 根据定义变量位置的不同,可以将变量分成两 ...

  2. es6之变量的解构赋值

    es5中通常我们声明变量都是以下的方式: var a = 10; var b = 20; var c = 30; //或者 var a = 10,b = 20,c = 30; //或者 var arr ...

  3. 变量的解构赋值////////////z

    变量的解构赋值 数组的解构赋值 对象的解构赋值 字符串的解构赋值 数值和布尔值的解构赋值 函数参数的解构赋值 圆括号问题 用途 数组的解构赋值 基本用法 ES6允许按照一定模式,从数组和对象中提取值, ...

  4. ES6 变量的解构赋值

    数组的解构赋值     var [a,b,c] = [1,2,3];    左边是变量,右边是值,根据数据结构一一对应 只要等号两边的模式相同,左边的变量就会被赋予右边对应的值,必须模式相同 如果等号 ...

  5. mysql show variables系统变量详解

    mysql系统变量详解 mysqld服务器维护两种变量.全局变量影响服务器的全局操作.会话变量影响具体客户端连接相关操作. 服务器启动时,将所有全局变量初始化为默认值.可以在选项文件或命令行中指定的选 ...

  6. ES 6 : 变量的解构赋值

    1. 数组的解构赋值 [ 基本用法 ] 按照一定的模式从数组或者对象中取值,对变量进行赋值的过程称为解构. 以前,为变量赋值只能直接指定值: 而ES 6 允许写成下面这样: 上面的代码表示,可以从数组 ...

  7. ECMAScript 6入门 - 变量的解构赋值

    定义 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 解构赋值不仅适用于var命令,也适用于let和const命令. 解构赋值的规则是,只要 ...

  8. ES6 继续 变量的解构赋值

    春节放假这几天,感觉跟梦一样,瞬间就过去了.现在上班的前几天,都感觉有点不真实,不过看到口袋里的钱,就知道,是真真实实的度过了这个假期. 现在得开始重新工作了: 变量的解构赋值 ES6 允许按照一定模 ...

  9. ECMAScript 6之变量的解构赋值

    1,数组的解构赋值 基本用法 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 以前,为变量赋值,只能直接指定值. var a = 1; va ...

  10. const命令,全局变量的属性,变量的解构赋值

    const命令 1:声明常量(只在当前代码块中有效)---注意声明的常量可以是对象,但是常量储存的是对象的地址,地址声明后不可变,但是可以给常量对象添加属性 全局变量的属性 1:window和glob ...

随机推荐

  1. [Go] CORS 支持多个 origin 访问的思路 (Access-Control-Allow-Origin 部分)

    以下为局部伪代码,仅供参考: var allowOrigin string allowOrigins := config.AppConf.Get("middleware.cors.allow ...

  2. dotnet 对指针转换为结构体多个不同方法的性能分析

    在 dotnet 里面,拿到一个指针,可以有多个不同的方法转换为结构体,本文将来告诉大家这几个方法的性能的差别 特别感谢性能优化狂魔 Stephen Toub 大佬的指导 在 WPF 框架开发中,有小 ...

  3. JUC并发编程学习笔记(二)Lock锁(重点)

    Lock锁(重点) 传统的synchronized 传统的解决多线程并发导致的一些问题我们会使用synchronized关键字来解决,synchronized的本质就是队列.锁. Lock的实现类有: ...

  4. vim 使用clang-format 格化C/C++/Java/JavaScript

    vim 使用clang-format 格化C/C++/Java/JavaScript 参考信息 官方参考https://clang.llvm.org/docs/ClangFormat.html 安装 ...

  5. ansible系列(22)--ansible的Facts Variables

    目录 1 Ansible Facts Variables 1.1 facts的获取方法 1.2 根据主机IP地址生成Redis配置文件 1.3 根据主机CPU核数生成Nginx配置 1.4 根据主机内 ...

  6. LVS负载均衡(1)-- LVS概述及LVS网络模型

    目录 1. 负载均衡集群概述 2. LVS理论基础 2.1 LVS常用术语 2.2 LVS数据调度原理 2.3 LVS工作模型 2.3.1 NAT模型 2.3.2 DR模型 2.3.3 TUNNEL模 ...

  7. 🔥🔥v1.9.2-httpsok快速申请免费谷歌SSL证书

    v1.9.2-httpsok快速申请免费谷歌SSL证书 介绍 httpsok 是一个便捷的 HTTPS 证书自动续签工具,专为 Nginx .OpenResty 服务器设计.已服务众多中小企业,稳定. ...

  8. three.js教程5-几何体顶点UV坐标、纹理贴图TextureLoader

    1.纹理贴图 纹理贴图,是给MeshLambertMaterial等材质一些纹理图片,以达到更好的视觉效果. 使用方法:通过纹理贴图加载器TextureLoader的load()方法加载一张图片可以返 ...

  9. 一文搞懂docker容器基础:docker镜像管理,docker容器管理

    目录 一.系统环境 二.docker 2.1 Docker 概述 2.2 Docker 平台 2.3 我可以使用 Docker 做什么? 2.3.1 快速.一致地交付您的应用程序 2.3.2 响应式部 ...

  10. IceRPC之深入理解调度管道->快乐的RPC

    作者引言 很高兴啊,我们来到了IceRPC之深入理解调度管道->快乐的RPC,为上篇的续篇,深入理解常见的调度类型, 基础引导,有点小压力,打好基础,才能让自已不在迷茫,快乐的畅游世界. 传入请 ...