温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

scala的抽象类型怎么定义

发布时间:2021-12-08 15:03:10 来源:亿速云 阅读:157 作者:iii 栏目:大数据

这篇文章主要介绍“scala的抽象类型怎么定义”,在日常操作中,相信很多人在scala的抽象类型怎么定义问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”scala的抽象类型怎么定义”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

特质和抽象类可以包含一个抽象类型成员,意味着实际类型可由具体实现来确定。例如:

trait Buffer {  type T  val element: T}

这里定义的抽象类型T是用来描述成员element的类型的。通过抽象类来扩展这个特质后,就可以添加一个类型上边界来让抽象类型T变得更加具体。

abstract class SeqBuffer extends Buffer {  type U  type T <: Seq[U]  def length = element.length}

注意这里是如何借助另外一个抽象类型U来限定类型上边界的。通过声明类型T只可以是Seq[U]的子类(其中U是一个新的抽象类型),这个SeqBuffer类就限定了缓冲区中存储的元素类型只能是序列。

含有抽象类型成员的特质或类(classes)经常和匿名类的初始化一起使用。为了能够阐明问题,下面看一段程序,它处理一个涉及整型列表的序列缓冲区。

abstract class IntSeqBuffer extends SeqBuffer {  type U = Int}def newIntSeqBuf(elem1: Int, elem2: Int): IntSeqBuffer =  new IntSeqBuffer {       type T = List[U]       val element = List(elem1, elem2)     }val buf = newIntSeqBuf(7, 8)println("length = " + buf.length)println("content = " + buf.element)

这里的工厂方法newIntSeqBuf使用了IntSeqBuf的匿名类实现方式,其类型T被设置成了List[Int]

把抽象类型成员转成类的类型参数或者反过来,也是可行的。如下面这个版本只用了类的类型参数来转换上面的代码:

abstract class Buffer[+T] {  val element: T}abstract class SeqBuffer[U, +T <: Seq[U]] extends Buffer[T] {  def length = element.length}
def newIntSeqBuf(e1: Int, e2: Int): SeqBuffer[Int, Seq[Int]] =  new SeqBuffer[Int, List[Int]] {    val element = List(e1, e2)  }
val buf = newIntSeqBuf(7, 8)println("length = " + buf.length)println("content = " + buf.element)

需要注意的是为了隐藏从方法newIntSeqBuf返回的对象的具体序列实现的类型,这里的型变标号(+T <: Seq[U])是必不可少的。此外要说明的是,有些情况下用类型参数替换抽象类型是行不通的。

到此,关于“scala的抽象类型怎么定义”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI