您的位置:首页 > 其它

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

2015-08-11 08:48 211 查看
学习了Scala中List的实现内幕源码揭秘,ListBuffer(链表缓存)相当于List的一个工具类,List本身继承ListBuffer,拥有ListBuffer中非私有的方法。对List的操作其实有部分是通过ListBuffer完成的。exported为LiftBuffer中flag(default:false),当flag为true时,表明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

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: