JavaAbstractListのindexOfとlastIndexOfの説明

ソースコード表示

indexOfのソースコード

    public int indexOf(Object o) {
    
    
        ListIterator<E> it = listIterator();
        if (o==null) {
    
    
            while (it.hasNext())
                if (it.next()==null)
                    return it.previousIndex();
        } else {
    
    
            while (it.hasNext())
                if (o.equals(it.next()))
                    return it.previousIndex();
        }
        return -1;
    }

lastIndexOfソースコード

 public int lastIndexOf(Object o) {
    
    
        ListIterator<E> it = listIterator(size());
        if (o==null) {
    
    
            while (it.hasPrevious())
                if (it.previous()==null)
                    return it.nextIndex();
        } else {
    
    
            while (it.hasPrevious())
                if (o.equals(it.previous()))
                    return it.nextIndex();
        }
        return -1;
    }

indexOf原則

最初の文は、最初にListIteratorクラスに属するイテレーターを生成し、通常のIterator Reasonの代わりにそれを選択します。通常のIteratorは前方にのみトラバースでき、ListIteratorにはLinkedListのような前のパラメーターがあります。または、後ろに向けることもできます。
その後、ifステートメントは、オブジェクトが空であるかどうかを確認します。空の場合は、前方にトラバースして、現在のList要素の総数を返します。空でない場合は、要素の正確な場所を返します。そうでない場合は、満足すると、-1を返します。

lastIndexOfの原則

原理はindexOfと同じですが、違いはlastIndexOfが前方にトラバースし、下からn番目の位置を返すことです。

おすすめ

転載: blog.csdn.net/deepdarkfan/article/details/100140834