kotlin学习(8)泛型

2023-06-07,,

泛型的声明

  与Java不同的是,Kotlin要求类型实参要么被显示的说明,要么能被编译器推导出来。因为Java在1.5版本才引入泛型,所以为了兼容过去的版本,可以不直接声明List类型的变量,而不说明类型。

//下面两种是等价的
val readers = arrayListOf<String>()
val readers:ArrayList<String>=arrayListOf()

泛型函数

//  第一处是类型形参声明,第二三处分别是接收者和返回类型使用了类型形参
fun <T> List<T>.slice(indices: IntRange): List<T>{
val res=arrayListOf<T>()
indices.forEach{
res.add(this[it])
}
return res
} //调用
>>>val letters=('a'..'z').toList()
>>>println(letters.slice<Char>(0..2)) //这里显式的指定类型实参
[a,b,c] >>>println(letters.slice(1..2)) //这里可以根据letters推导出类型为Char
[a,b,c]

  泛型属性同理

泛型类

//List接口定义了类型参数T
interface List<T>{
//在类或接口的内部,T可以当作普通类型使用
operator fun get(index: Int): T
} //这个类实现了List,提供了具体类型实参String
class StringList: List<String>{
override get(index: Int): String { //xxxxx }
} //现在ArrayList的泛型类型形参T就是List的类型实参
class ArrayList<T>: List<T>{
override get(index: Int): T { //xxxxx }
}

类型参数约束

  “ <T extends Number> ”代表类型形参一定属于Number类型,限制了它的上界。

让类型形参非空

  " <T : Any> " 代表T的类型一定是非空的,它不接受传入<String?>这样的可空实参。

不能指定具体类型实参的情况下可以用*

   if ( value is List<*> ){ ... } 这样之判断了value是否为List,而不用在意类型实参具体是什么。

kotlin学习(8)泛型的相关教程结束。

《kotlin学习(8)泛型.doc》

下载本文的Word格式文档,以方便收藏与打印。