首页 > 其他 > 详细

使用泛型实现栈结构

时间:2014-06-20 09:07:59      阅读:345      评论:0      收藏:0      [点我收藏+]

   泛型类就是含有一个或者多个类型参数的类。定义泛型类很简单,只需要在类的名称后面加上“<”和“>”,并在其中指明类型参数,比如本例中的T。

也可以在其中指明多个参数,如K、V。多个参数之间使用逗号隔开。定义完类后,就可以在类中的域和方法中使用泛型参数。

注意: 泛型类型的参数只能使用类类型,而不能使用基本类型

设计过程:

1)编写泛型类Stack,在该类中定义了3个方法,分别用来入栈的push()方法、用来出栈的pop()方法和用来判断栈是否为空的empty()方法。在底层上,本类使用LinkedList作为容器,它是Java集合类的一员,可以用来简化开发。代码如下:

 

public class Stack<T> {
    
    private LinkedList<T> container = new LinkedList<T>();
    
    public void push(T t) {
        container.addFirst(t);
    }
    
    public T pop() {
        return container.removeFirst();
    }
    
    public boolean empty() {
        return container.isEmpty();
    }
}


2)编写测试代类StackTest,在该类的main()方法中向栈中增加3个字符串,又从栈中删去3个字符串并进行输出。代码如下:

public class StackTest {
    public static void main(String[] args) {
        Stack<String> stack = new Stack<String>();
        System.out.println("向栈中增加字符串:");
        System.out.println("视频学Java");
        System.out.println("细说Java");
        System.out.println("Java从入门到精通(第2版)");
        stack.push("视频学Java");  //向栈中增加字符串
        stack.push("细说Java");   //向栈中增加字符串
        stack.push("Java从入门到精通(第2版)"); //向栈中增加字符串
        System.out.println("从栈中取出字符串:");
        while (!stack.empty()) {
            System.out.println((String) stack.pop());//删除栈中全部元素并进行输出
        }
    }
}

结果如下:

bubuko.com,布布扣

使用泛型实现栈结构,布布扣,bubuko.com

使用泛型实现栈结构

原文:http://blog.csdn.net/sanqima/article/details/28588073

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!