我以下隊列類:隊列長度
class Queue
{
private Object[] data;
private int numOfElements;
private int head;
private int tail;
Queue(int size)
{
if (size <= 0)
throw new IllegalArgumentException("Size must be greater or equals 0.");
data = new Object[size];
head = 0;
tail = 0;
numOfElements = 0;
}
void enqueue(Object obj)
{
data[tail] = obj;
tail = (tail + 1) % data.length;
if (numOfElements < data.length)
numOfElements++;
}
Object dequeue()
{
if (numOfElements == 0)
throw new EmptyQueueException();
Object dequeuedObject = data[head];
data[head] = null;
head = (head + 1) % data.length;
numOfElements--;
return dequeuedObject;
}
我稱這樣的方法排隊:test_queue.enqueue(new Event(arg1, arg2));
的Event
對象包含被設置爲Arg1的值和兩個整數ARG2。方法enqueue
中的data.length
如何工作? 它如何正確獲取Event對象的大小?
'data'只是一個數組(長度),Event的大小是無關緊要的,那麼究竟是什麼意思? – harold
在這裏尋找有關'長度'字段的解釋:http://stackoverflow.com/questions/5950155/java-array-length – maksimov