一、Kotlin常量与变量
1-1、变量
Kotlin中变量的声明,必须使用 val 或 var 关键字;其声明方式有(中括号里的为可选):
val/var <propertyName> [ : <propertyType>] [ = <property_initializer> ] [ <getter> ] [ <setter> ]
1、变量的种类:
①可变变量(var):可变变量的值可以被改变,其没有固定值;相当于java中的普通变量
②不可变变量(val):不可变变量的值是不可改变的,其被定义后,在程序的任何地方都不能改变它的值;相当于java中用final修饰的变量
2、变量的作用域:
作用域是指花括号括起来的代码块,变量仅存在于声明了它的作用域,根据作用域的不同,变量可分为全局变量和局部变量;
①全局变量:主要指在顶层定义的变量 或 类中的定义的成员变量;
②局部变量:主要指在方法中定义的变量;
※※※Kotlin中关于变量的声明,有以下需要注意的点:
①Kotlin中,可以声明一个变量为可空变量;其在声明时,不能用可推断类型的简写;并需在变量类型后面补上修饰符 ‘?’;
②Kotlin中,当声明类的属性的时候,必须初始化;如果不初始化的话,需使用关键字 lateinit 声明后期初始化属性,在Android中,多用于声明控件组件;lateinit 修饰的必须是var声明的变量,且不能修饰可空变量,也不能修饰基本数据类型的变量;
例:private lateinit var mTabLayout:TabLayout
③延迟初始化:指当程序在第一次使用到这个变量(属性)的时候在初始化;需要使用到 lazy{} 高阶函数;其使用需放在变量的数据类型后,用by链接,且不能用于数据推断,对应的必须是val声明的只读变量;
例:private val mStr : String by lazy{ "我是延迟初始化字符串变量" }
1-2、常量
Kotlin中常将 val 修饰的称为常量,其实其只能算是一个不能修改的变量;要声明常量,还需要在 val 前面加上 const 关键字;
常量的声明方法有以下三种:
①在顶层声明;
②在object修饰的类中声明;※ object 修饰的类相当于java中的一种单例类;
③在伴生对象中声明;
1-3、注释
Kotlin中的注释与java中的注释几乎没有区别;唯一区别在于Kotlin中的多行注释中可以嵌套多行注释;
Kotlin中的注释也分为以下三种:
①单行注释;例://我是一个注释
②多行注释(多行注释可以嵌套使用);例:/*我是一个注释*/
③类注释/方法注释;例:/**我是一个注释*/
二、Kotlin数据类型
链接:Kotlin——初级篇(三):数据类型详解
基本类型:数字、字符串、数组 - Kotlin语言中文站
在Kotlin中有两种数据类型:基本数据类型与引用数据类型
基本数据类型:布尔类型(Boolean)、数值类型(Number)、字符类型(Char)
引用数据类型:可空类型(Null)、对象类型(Object)、数组类型(Array)
2-1、布尔类型(Boolean)
布尔类型是比较常见的数据类型,它只有true和false两个值;
在Kotlin中提供了内置的布尔类型运算,如逻辑或(||)、逻辑与(&&)、逻辑非(!)
2-2、数值类型(Number)
数值类型包括 字节型、整型、以及浮点型;
①字节型:字节类型(Byte)
②整型:短整型(Short)、整型(Int)、长整型(Long)
③浮点型:双精度浮点型(Double)、单精度浮点型(Float)
1、字面常量:
数值类型的字面常量按类型的不同有不同的体现:
①整型数值字面常量:默认为Int;Long(...L);二进制(0b...),十六进制(0x...)...等形式(※Kotlin中不支持八进制数);
②浮点数值字面常量:默认为Double;Float(...f/...F);科学计数(..E..或..e..)...等形式;
③整型数值下划线展示:在Kotlin中展示整型数值时,为了方便阅读,可以使用下划线分割数值;例:0xFF_EC_5E...等
2、数值数据类型转换:
Kotlin中,由于不能将较小的数据类型隐式的转换为较大的类型,如若想进行转换,只能通过显示调用相关的转换方法:
toByte()、toShort()、toInt()、toLong()、toFloat()、toDouble()、toChar()...等
3、装箱与拆箱:
在Kotlin中,本着万般皆对象的原则,其严格来说是没有基本数据类型的,上面所说的基本数据类型都是指他们的引用类型;
因此,在Kotlin中,其不像java中存在装箱与拆箱
4、相关注意知识点:
① 可空整型与非空整型区别:非空整型映射为java的基本类型;可空整型映射为java的引用类型;在使用"==="运算符时需注意;
② Kotlin中提供了三种特殊的浮点型数值;正无穷大,负无穷大,非数;
正浮点型除以0将得到正无穷大;负浮点型除以0将得到负无穷大;0除以0或对负数开方将得到非数;
所有的正无穷大都相等;所有的负无穷大都相等;所有的非数与任何值都不相等(包括非数自己);
③ Kotlin中缺乏隐式转换,但在表达式中可以自动转换;
④ 字符类型虽然不能作为整数进行算术运算;但Kotlin中为Char类型提供了加、减运算支持;
Char型值可以加、减一个整型值;两个Char型值可以进行减法运算,但是不能进行加法运算;
2-3、字符类型(Char)
字符类型变量用单引号(‘’)表示,其不能直接视为数字,不过可以显式转换为数字或其他类型;
同java一样,使用某些特殊的字符时,要使用转义;下列是支持的转义序列:
①\t:表示制表符
②\n:表示换行符
③\b:表示退格键(键盘上的Back键)
④\r:表示键盘上的Enter转行符
⑤\\:表示反斜杠
⑥\':表示单引号
⑦\":表示双引号
⑧\&:表示美元符号
2-4、可空类型(Null)
Kotlin与Java最大的一个区别:Kotlin为了尽量避免空引用所带来的危险(例:NPE),将可空类型和不可空类型进行了区分;在Kotlin中声明可空类型,需要在变量类型后补充 ? ;当变量声明为可空类型时,其才能被赋值为null,负责会编译不通过;
2-5、字符串类型(String)
链接:Kotlin——初级篇(八):关于字符串(String)常用操作汇总
同java一样,Kotlin中字符串也用String表示;其也具有不可变性;其也可以看作是字符(Char)的数组,可通过索引运算符[ ]取得指定位置的字符,可以使用for循环迭代字符串中的字符;
1、字符串(String)的数组特性:
字符串(String)可以看作是字符(Char)的数组;其具有下面这些数组的特性:
①可通过 索引操作符[ ] 取指定位置的字符;
②可使用 for循环 迭代字符串中的字符;
③可通过 .length 获取字符串的长度;
2、字符串字面值:
Kotlin 有两种类型的字符串字面值: 转义字符串 与 原始字符串
转义字符串:用双引号("...")括起来的,包含转义字符(\n、\t...等)的字符串;
原始字符串:用三重分解符("""...""")括起来的,包含任意字符的字符串;
3、字符串模板:
在Kotlin中,使用字符串模板的符号为 $,在 $ 符号后面加上变量名或花括号 { } 中的表达式;原始字符串与转义字符串内部都支持字符串模板;
4、字符串(String)常用的函数方法:
字符串(String),作为最常用的对象类型,其有以下常用的函数方法:
①读取元素:str[index]、str.first()、str.last()、str.indexOf()、str.lastIndexOf()
②截取:str.substring()、str.substringBefore()、str.substringAfter()、str.substringBeforeLast()、str.substringAfterLast()
③移除:str.drop()、str.dropLast()
④替换:str.replace()、str.replaceBefore()、str.replaceAfter()、str.replaceBeforeLast()、str.replaceAfterLast()
⑤其他函数:str.plus()/+、str.equals()、str.split()、str.isBlank()、str.isEmpty()、str.reversed()、str.startsWith()、str.endsWith()、str.trim()
2-6、数组类型(Array)
链接:基本类型:数字、字符串、数组 - Kotlin语言中文站
1、数组Array:
①Array数组的声明初始化方法:
● 使用构造函数 constructor(size: Int, init: (Int) ->T),此构造函数第一个参数为数组大小,第二个参数为一个函数参数;(例:Array(3,{it->3}),Array(4,{i->i*i})...等)
● 使用库函数 arrayOf(),创建一个数组并传递元素值;(例:arrayOf(1,2,3),arrayof(1,"String",true)...等)
● 使用库函数 arrayOfNulls(),创建一个定长的所有元素都为空的数组;(例:arrayOfNulls(5)...等)
● 使用库函数 emptyArray(),创建一个空的数组;
②Array数组指定项的读写方法:
● 通过索引运算符 [ ];(例:array[position]=xxx)
● 通过 set(index:Int,value:T) 与 get(index:Int) 方法;(例:array.set(position,xxx),array.get(position)...等)
③Array数组循环获取子项的方法:
● 通过 in 操作符循环数组的索引(通过Array.indices获取对应的索引数组);(例:for(index in array.indices){...})
● 通过 in 操作符直接循环数组的value值;(例:for(value in array){...})
● 通过数组对象的.forEach{...}函数循环获取对应的值;
● 通过数组对象的.withIndex()函数同时获取数组的索引以及值的循环遍历;
④Array数组.joinToString()方法说明:
概述:Array.joinToString()方法是将Array数组转换为String输出的方法,该方法参数有:
● prefix:数组开始标记,默认没有;一般常用的有"[","<"...等
● postfix:数组结束标记,默认没有;一般常用的有"]",">"...等
● separator:数组元素分割标记,默认为",";一般常用的有",","、"...等
● limit:最多展示元素个数限制标记,默认全部展示;
● truncated:当数组元素超过最多个数限制时,其他元素的缩略展示;常用的有"..."等
2、原生类型数组(XXXArray):
Kotlin中还准备了无装箱开销的专门的类来表示原生类型数组(IntArray、ByteArray、CharArray...等);
①XXXArray原生类型数组的声明初始化方法:
● 使用构造函数constructor(size: Int),创建一个定长的所有元素都为默认值(未指定时为系统默认值)的数组;
● 使用构造函数constructor(size: Int,init: (Int) ->T),此构造函数第一个参数为数组大小,第二个参数为一个函数参数;也可将函数参数放在括号收后,写为constructor(size: Int)init: (Int) ->T;
● 使用库函数 xxxArrayOf(),创建一个数组并传递元素值;
②XXXArray原生类型数组指定项的读写方法:(同上方一致)
③Array数组循环获取子项的方法:(同上方一致)
3、多维数组:
※※※关于数组,有下面需要注意的:
① Kotlin 中数组是不型变的(invariant),意味着 Kotlin 不让我们把 Array<String> 赋值给 Array<Any>,但可以使用 Array<out Any>,参见类型投影;
② Kotlin 中原生类型数组XXXArray与Array并没有继承关系,但是他们有相同的方法属性集,也都有对应的工厂方法;
2-7、元组类型(Pair/Triple)
元组是一个简便用法,其可以将多个值同时赋给一个变量,或者同时给多个变量赋值;在Kotlin中,元组分为二元元组(Pair)与三元元组(Triple),在使用元组时,有下面这些需要注意的:
①元组中的字段是只读的;即,当元组在首次初始化后,便只能从元组中取值,不能重新赋值;
②新版本的Kotlin中,将多元元组去掉了,只保留了二元元组与三元元组;
③我们可以依照二元元组或三元元组的源码,自定义属于自己的多元元组;
2-8、数据类型转换:
编程语言无论是强类型的(如java)还是弱类型的(如PHP),都会进行类型转换,Kotlin提供了5种数据类型转换方式:
①智能转换:某些场景编译器会根据上下文来推断转换变量的数据类型;例:使用 is 操作符来判断变量是否是某类型时;
②不安全转换(as):如果遇到不可能被转换的情况或者变量为Null值时,会抛出异常;
③安全转换(as?):为了避免上述抛出异常的状况,使用as?,当转换失败时会返回Null;
④显式转换:在Kotlin中,由于不能将较小的数据类型隐式的转换为较大的类型;若想实现该转换,只能通过显式调用转换toXXX()方法进行转换;
⑤隐式转换:是指在运算过程中进行的转换;例:val a=1L+3;
※※※与java语言的相关区别:
①Kotlin中对应整型的字面量中不支持八进制;支持二进制(0b),十进制(正常),十六进制(0x);
②Kotlin的一大特点便是如许多现代语言一样,可以进行数据类型推断;即:未指定数据类型的数据,系统会自动为其推断出数据类型;
⑤Kotlin中的字符类型Char不能直接当作数字,其可以通过toInt()转换为数字,Int类型数字亦可以通过toChar()转换为字符类型;