下面温习一下由尺度Java(1.0和1.1)库提供的荟萃(BitSet未包罗在这里,因为它更象一种负有非凡使命的类):
(1) 数组包括了工具的数字化索引。它容纳的是一种已知范例的工具,所以在查找一个工具时,不必对功效举办造型处理惩罚。数组可以是多维的,并且可以或许容纳根基数据范例。可是,一旦把它建设好今后,巨细便不能变革了。
(2) Vector(矢量)也包括了工具的数字索引——可将数组和Vector想象成随时机见荟萃。当我们插手更多的元素时,Vector可以或许自动改变自身的巨细。但Vector只能容纳工具的句柄,所以它不行包括根基数据范例;并且将一个工具句柄从荟萃中取出来的时候,必需对功效举办造型处理惩罚。
(3) Hashtable(散列表)属于Dictionary(字典)的一种范例,是一种将工具(而不是数字)同其他工具关联到一起的方法。散列表也支持对工具的随时机见,事实上,它的整个设计方案都在突出会见的“高速度”。
(4) Stack(仓库)是一种“后入先出”(LIFO)的行列。
若你曾经熟悉数据布局,大概会迷惑为何没看到一套更大的荟萃。从成果的角度出发,你真的需要一套更大的荟萃吗?对付Hashtable,可将任何对象置入个中,并以很是快的速度检索;对付Enumeration(列举),可遍历一个序列,并对个中的每个元素都采纳一个特定的操纵。那是一种成果足够强劲的东西。
但Hashtable没有“顺序”的观念。Vector和数组为我们提供了一种线性顺序,但若要把一个元素插入它们任何一个的中部,一般都要支付“惨重”的价钱。除此以外,行列、拆散行列、优先级行列以及树都涉及到元素的“排序”——并非仅仅将它们置入,以便今后能按线性顺序查找或移动它们。这些数据布局也很是有用,这也正是尺度C++中包括了它们的原因。思量到这个原因,只应将尺度Java库的荟萃看作本身的一个起点。并且倘若必需利用Java 1.0或1.1,则可在需要逾越它们的时候利用JGL。
假如能利用Java 1.2,那么只利用新荟萃即可,它一般能满意我们的所有需要。留意本书在Java 1.1身上花了大量篇幅,所以书顶用到的大量荟萃都是只能在Java1.1顶用到的那些:Vector和Hashtable。就今朝来看,这是一个不得以而为之的做法。可是,这样处理惩罚亦可提供与老Java代码更精彩的向后兼容本领。若要用Java1.2写新代码,新的荟萃往往能更好地为你处事。