不同在于删除或者访问对象的顺序不同
1.1 泛型
集合类的抽象数据类型的一个关键特性是我们应该可以用它们存储任意类型的数据。
Java一种机制可以实现,它叫做泛型,也叫做参数化类型。
1.2 自动装箱
1.4 背包
一种不支持从中删除元素的集合数据类型
它的目的就是帮助用例收集元素并迭代遍历所有收集到的元素。
使用Bag可以说明元素的处理顺序不重要。
1.6 下压栈,简称栈
使用foreach语句迭代遍历栈中元素的时候,元素的处理顺序和它们被压入的顺序正好相反。
2.集合类数据类型的实现
2.4 对象游离
保存一个不需要的对象的引用称为游离。(栈的pop)
解决:将被弹出的数组元素的值设为null即可,这将覆盖无用的引用并使系统可以在用例使用完被弹出的元素后回收它的内存。
2.5 迭代
3.链表
定义:链表是一种递归的数据结构,它或者为空(null),或者是指向一个结点(node)的引用,该结点含有一个泛型的元素和一个指向另一条链表的引用
链表比数组插入元素或是删除元素都更方便
实现任意插入和删除操作的标准解决方案是双向链表
3.8 栈的实现
栈是由链表实现
链表的使用达到了最优的设计目标:
它可以处理任意类型的数据
所需的空间总是和集合的大小成正比
操作所需的时间总是和集合的大小无关
3.9 队列的实现
3.10 背包的实现
总结
数据类型的值就是一组对象的集合:背包、队列、栈(三种基础数据类型)
两种表示对象集合的方式:数组和链表
答疑
为什么Java不允许泛型数组?
数组的协变性(covariant)是指:
如果类Base是类Sub的基类,那么Base[]就是Sub[]的基类。
而泛型是不可变的(invariant),List不会是List的基类,更不会是它的子类。
数组是具体化的(reified),而泛型在运行时是被擦除的(erasure)。
数组是在运行时才去判断数组元素的类型约束,
而泛型正好相反,在运行时,泛型的类型信息是会被擦除的,只有编译的时候才会对类型进行强化。
前序表达式():即从右至左取数,直到取出一个运算符,将刚取出的紧挨着运算符的两个操作数按运算符进行计算,结果回填至运算符。重复该步骤,直到最后只剩下一个字符串则剩下的字符串即为结果。
中序表达式:我们平时用的
后序表达式:字符串扫描方式正好和前序相反,是从左往右扫描,规则类似。
前序表达式
+/*23-21*3-41
中序表达式
2*3/(2-1)+3*(4-1)
后序表达式
23*21-/341-*+
网友评论