Scala中List的实现内幕源码揭秘

学习了ScalaList的实现内幕源码揭秘,ListBuffer(链表缓存)相当于List的一个工具类,List本身继承ListBuffer,拥有ListBuffer中非私有的方法。对List的操作其实有部分是通过ListBuffer完成的。exportedLiftBufferflagdefault:false),当flagtrue时,表明Buffer已进行了toList操作,此时再进行连接等操作时,会有copy链表的动作发生,消耗内存,在实际编程中应谨慎。

例子如下:

private var start:List[A] = Nil

private var last0: ::[A]=_

private exported:Boolean = false

private var len = 0

override def toList:List[A]={

   exported = !start.isEmpty

   start

}

def +=(x:A): this.type = {

    if(exported)copy()

    .....

}

 

 王家林亲授《DT大数据梦工厂》大数据实战视频“Scala深入浅出实战经典”视频、音频和PPT下载!第83讲:Scala中List的实现内幕源码揭秘
百度云盘:http://pan.baidu.com/s/1sJWxo
360云盘:http://yunpan.cn/cdPEbk8TREFgt  访问密码 f2eb

posted on 2015-08-11 08:48  l_time  阅读(291)  评论(1)    收藏  举报

导航