kotlin学习(8)泛型

泛型的声明

  与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,而不用在意类型实参具体是什么。

原文地址:https://www.cnblogs.com/liumaowu/p/9408077.html