科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道java.util 第1部分:类集框架 (20)

java.util 第1部分:类集框架 (20)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

java.util 第1部分:类集框架 (20)

作者:Herbert Schildt 著 张玉清 吴溥峰等 译 来源:清华大学出版社 2007年10月30日

关键字: 类集框架 java.util

  • 评论
  • 分享微博
  • 分享邮件

15.10.3 Stack
Stack是Vector的一个子类,它实现标准的后进先出堆栈。Stack仅仅定义了创建空堆栈的默认构造函数。Stack包括了由Vector定义的所有方法,同时增加了几种它自己定义的方法,具体总结在表15-11中。
表15-11 由Stack 定义的方法
方法 描述
boolean empty( ) 如果堆栈是空的,则返回true,当堆栈包含有元素时,返回false
Object peek( ) 返回位于栈顶的元素,但是并不在堆栈中删除它
Object pop( ) 返回位于栈顶的元素,并在进程中删除它
Object push(Object element) 将element压入堆栈,同时也返回element
int search(Object element) 在堆栈中搜索element,如果发现了,则返回它相对于栈顶的偏移量。否则,返回-1
调用push( )方法可将一个对象压入栈顶。调用pop( )方法可以删除和返回栈顶的元素。当调用堆栈是空的时,如果调用pop( )方法,将引发一个EmptyStackException异常。调用peek( )方法返回但不删除栈顶的对象。调用empty( )方法,当堆栈中没有元素时,返回true。search( )方法确定一个对象是否存在于堆栈,并且返回将其指向栈顶所需的弹出次数。下面是一个创建堆栈的例子,在例子中,将几个整型(Integer)对象压入堆栈,然后再将它们弹出。
// Demonstrate the Stack class.
import java.util.*;
class StackDemo {
static void showpush(Stack st, int a) {
st.push(new Integer(a));
System.out.println("push(" + a + ")");
System.out.println("stack: " + st);
}
static void showpop(Stack st) {
System.out.print("pop -> ");
Integer a = (Integer) st.pop();
System.out.println(a);
System.out.println("stack: " + st);
}
public static void main(String args[]) {
Stack st = new Stack();
System.out.println("stack: " + st);
showpush(st, 42);
showpush(st, 66);
showpush(st, 99);
showpop(st);
showpop(st);
showpop(st);
try {
showpop(st);
} catch (EmptyStackException e) {
System.out.println("empty stack");
}
}
}
下面是由该程序产生的输出。注意对于EmptyStackException的异常处理程序是如何被
捕获以便于能够从容地处理堆栈的下溢:
stack: [ ]
push(42)
stack: [42]
push(66)
stack: [42, 66]
push(99)
stack: [42, 66, 99]
pop -> 99
stack: [42, 66]
pop -> 66
stack: [42]
pop -> 42
stack: [ ]
pop -> empty stack
15.10.4 Dictionary
字典(Dictionary)是一个表示关键字/值存储库的抽象类,同时它的操作也很像映射(Map)。给定一个关键字和值,可以将值存储到字典(Dictionary)对象中。一旦这个值被存储了,就能够用它的关键字来检索它。因此,与映射一样,字典可以被当做关键字/值对列表来考虑。尽管在Java 2中并没有摈弃字典(Dictionary),由于它被映射(Map)所取代,从而被认为是过时的。然而由于目前Dictionary被广泛地使用,因此这里仍对它进行详细的讨论。
由Dictionary定义的抽象方法在表15-12中列出。
表15-12 由Dictionary 定义的抽象方法
方法 描述
Enumeration elements( ) 返回对包含在字典中的值的枚举
Object get(Object key) 返回一个包含与key相连的值的对象。如果key不在字典中,则返回一个空对象
boolean isEmpty( ) 如果字典是空的,则返回true;如果字典中至少包含一个关键字,则返回false
Enumeration keys( ) 返回包含在字典中的关键字的枚举
Object put(Object key, Object value) 将一个关键字和它的值插入字典中。如果key已经不在字典中了,则返回null;如果key已经在字典中了,则返回与key相关联的前一个值
续表
方法 描述
Object remove(Object key) 删除key和它的值。返回与key相关联的值。如果key不在字典中,则返回null
int size( ) 返回字典中的项数
使用put( )方法在字典中增加关键字和值。使用get( )方法检索给定关键字的值。当分别使用keys( )和elements( )方法进行枚举(Enumeration)时,关键字和值可以分别逐个地返回。
size( )方法返回存储在字典中的关键字/值对的个数。当字典是空的时候,isEmpty( )返回true。
使用remove( )方法可以删除关键字/值对。
注意:Dictionary类是过时的。应该执行Map接口去获得关键字/值存储的功能。
查看本文来源
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章