- 用JAVA編寫一個隊列類實例 推薦度:
- 相關(guān)推薦
Java隊列類編寫實例
隊列是只允許在一端進(jìn)行插入,而在另一端進(jìn)行刪除的運算受限的線性表。下面是小編分享的Java隊列類編寫實例,一起來看一下吧。
enq(x) 向隊列插入一個值為x的元素;
deq() 從隊列刪除一個元素;
front() 從隊列中讀一個元素,但隊列保持不變;
empty() 判斷隊列是否為空,空則返回真;
clear() 清空隊列;
search(x) 查找距隊首最近的元素的位置,若不存在,返回-1。
Vector類是JAVA中專門負(fù)責(zé)處理對象元素有序存儲和任意增刪的類,因此,用Vector
可以快速實現(xiàn)JAVA的隊列類。
public class Queue extends java
public synchronized void enq(ob ject x) {
super.addElement(x);
}
public synchronized ob ject deq() {
/* 隊列若為空,引發(fā)EmptyQueueException異常 */
if( this.empty() )
throw new EmptyQueueException();
ob ject x = super.elementAt(0);
super.removeElementAt(0);
return x;
}
public synchronized ob ject front() {
if( this.empty() )
throw new EmptyQueueException();
return super.elementAt(0);
}
public boolean empty() {
return super.isEmpty();
}
public synchronized void clear() {
super.removeAllElements();
}
public int search(ob ject x) {
return super.indexOf(x);
}
}
public class EmptyQueueException extends java
}
以上程序在JDK1.1.5下編譯通過
【Java隊列類編寫實例】相關(guān)文章:
用JAVA編寫一個隊列類實例10-09
編寫一個JAVA的隊列類11-12
用Java編寫一個隊列類06-02
如何編寫一個JAVA的隊列類08-27
java程序編寫10-10
php語言redis隊列操作實例08-19
如何編寫java程序07-05
關(guān)于Java中的阻塞隊列05-28