0

コードはコンパイルされますが、機能しません。私は正しく型キャストしなかったと思いますか?そして誰かが私にwrapIdxメソッドがインデックス%容量を返すことを説明できますか?そのコードが配列をどのようにラップするかはよくわかりません。配列インデックスの最後に達すると、%容量は1を返しますが、配列は0インデックスで開始しませんか?

これが私のコードです。Queue12インターフェースを実装しています。これを機能させた後、それが機能するかどうかを確認するためのテストクラスを作成できますか?

import java.util.NoSuchElementException;


public class QueueImpl12<T> implements Queue12<T> 
{

private int _size, _backIdx, _frontIdx;
private static final int _defaultCapacity = 128;
private T[] _ringBuffer;



public QueueImpl12(int capacity)
{
    _ringBuffer = (T[]) new Object[capacity];
    clear();    
}


public QueueImpl12()
{
    _ringBuffer = (T[]) new Object[_defaultCapacity];
    clear();
}

private int wrapIdx(int index)
{

    return index % capacity();
}



public void clear() 
{
    _backIdx = 0;
    _frontIdx = 0;
    _size = 0;

}

@Override
public int capacity() 
{
    // TODO Auto-generated method stub
    return _ringBuffer.length;
}

@Override
public int size() 
{
    // TODO Auto-generated method stub
    return _size;
}

@Override
public boolean enqueue(T o) 
{
    //add o to back of queue


    if(_ringBuffer.length == _size)
    {
        return false;
    }


       _ringBuffer[_backIdx] = o;
        _backIdx = wrapIdx(_backIdx + 1 );
        _size++;





    return true;
}

@Override
public T dequeue()
{
    if(_size == 0)  //empty list
    {
        throw new NoSuchElementException();
    }

    T tempObj = _ringBuffer[_frontIdx];     //store frontIdx object
    _ringBuffer[_frontIdx] = null;          
    _frontIdx++;



    _size--;
    return tempObj;
}

@Override
public T peek() 
{

    return _ringBuffer[_frontIdx];
}

}
4

1 に答える 1

1

したがって、ここで最初に注意することは、モジュロ演算子%が除算の余りを返すことです。モジュロ自体の数値は0であるため、キューの最大容量に達すると、開始するインデックスである0が返されます。コードが最後に到達したときにコードが1を返す場合は、1つの問題があります。

于 2011-08-24T14:11:42.320 に答える