Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/performance/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 尝试创建堆栈类whare on类可以处理不同的数据类型_Java - Fatal编程技术网

Java 尝试创建堆栈类whare on类可以处理不同的数据类型

Java 尝试创建堆栈类whare on类可以处理不同的数据类型,java,Java,我创建了一个类来模拟堆栈。现在该类型已固定为浮动。我在java util类中看到,它们有一个堆栈类,您可以定义类型 我找不到任何关于如何创建一个类的信息,在这个类中,当对象被创建时,可以为它的一个verbol定义一个类型。我试着用谷歌搜索java模板totiol,我想在c语言中他们称之为模板 所以我有一个公共类cStack{ float data[]; int size=0; int pes=0; cStack(int size) { data=new float[size];

我创建了一个类来模拟堆栈。现在该类型已固定为浮动。我在java util类中看到,它们有一个堆栈类,您可以定义类型

我找不到任何关于如何创建一个类的信息,在这个类中,当对象被创建时,可以为它的一个verbol定义一个类型。我试着用谷歌搜索java模板totiol,我想在c语言中他们称之为模板

所以我有一个公共类cStack{

float data[];
int size=0;
int pes=0;

cStack(int size)
{
    data=new float[size];
    pes=0;
}

现在数据被定义为浮点数,我希望在创建类时可以设置类型。这样它就可以保存浮点数、整数或字符串。

这是Bruce Eckel的“”中的通用LinkedStack实现:

公共类LinkedStack{
私有静态类节点{
U项目;
节点下一步;
节点(){
item=null;
next=null;
}
节点(U项,下一个节点){
this.item=项目;
this.next=next;
}
布尔结束(){
返回项==null&&next==null;
}
}
private Node top=new Node();//结束sentinel
公共无效推送(T项){
top=新节点(项目,top);
}
公共广播电台{
T结果=top.item;
如果(!top.end())
top=top.next;
返回结果;
}
公共静态void main(字符串[]args){
LinkedStack lss=新LinkedStack();
用于(字符串s:“相位器电击!”。拆分(“”)
lss.推送;
字符串s;
而((s=lss.pop())!=null)
系统输出打印项次;
}
}
我建议您阅读整本书,尤其是“泛型”一章。

google“java泛型”。您还需要了解基本包装类,例如java.lang.Integer。
    public class LinkedStack<T> {
        private static class Node<U> {
            U item;
            Node<U> next;

            Node() {
                item = null;
                next = null;
            }

            Node(U item, Node<U> next) {
                this.item = item;
                this.next = next;
            }

            boolean end() {
                return item == null && next == null;
            }
        }

        private Node<T> top = new Node<T>(); // End sentinel

        public void push(T item) {
            top = new Node<T>(item, top);
        }

        public T pop() {
            T result = top.item;
            if (!top.end())
                top = top.next;
            return result;
        }

        public static void main(String[] args) {
            LinkedStack<String> lss = new LinkedStack<String>();
            for (String s : "Phasers on stun!".split(" "))
                lss.push(s);
            String s;
            while ((s = lss.pop()) != null)
                System.out.println(s);
        }
    }