Class AbstractLinkedList<E>

  • Type Parameters:
    E - the type of elements in this list
    All Implemented Interfaces:
    java.lang.Iterable<E>, java.util.Collection<E>, java.util.List<E>
    Direct Known Subclasses:
    CursorableLinkedList, NodeCachingLinkedList

    @Deprecated
    public abstract class AbstractLinkedList<E>
    extends java.lang.Object
    implements java.util.List<E>
    Deprecated.
    An abstract implementation of a linked list which provides numerous points for subclasses to override.

    Overridable methods are provided to change the storage node and to change how nodes are added to and removed. Hopefully, all you need for unusual subclasses is here.

    Since:
    3.0
    • Constructor Summary

      Constructors 
      Modifier Constructor Description
      protected AbstractLinkedList()
      Deprecated.
      Constructor that does nothing (intended for deserialization).
      protected AbstractLinkedList​(java.util.Collection<? extends E> coll)
      Deprecated.
      Constructs a list copying data from the specified collection.
    • Method Summary

      All Methods Instance Methods Concrete Methods Deprecated Methods 
      Modifier and Type Method Description
      void add​(int index, E value)
      Deprecated.
       
      boolean add​(E value)
      Deprecated.
       
      boolean addAll​(int index, java.util.Collection<? extends E> coll)
      Deprecated.
       
      boolean addAll​(java.util.Collection<? extends E> coll)
      Deprecated.
       
      boolean addFirst​(E e)
      Deprecated.
      Adds an element at the beginning.
      boolean addLast​(E e)
      Deprecated.
      Adds an element at the end.
      protected void addNode​(AbstractLinkedList.Node<E> nodeToInsert, AbstractLinkedList.Node<E> insertBeforeNode)
      Deprecated.
      Inserts a new node into the list.
      protected void addNodeAfter​(AbstractLinkedList.Node<E> node, E value)
      Deprecated.
      Creates a new node with the specified object as its value and inserts it after node.
      protected void addNodeBefore​(AbstractLinkedList.Node<E> node, E value)
      Deprecated.
      Creates a new node with the specified object as its value and inserts it before node.
      void clear()
      Deprecated.
       
      boolean contains​(java.lang.Object value)
      Deprecated.
       
      boolean containsAll​(java.util.Collection<?> coll)
      Deprecated.
       
      protected AbstractLinkedList.Node<E> createHeaderNode()
      Deprecated.
      Creates a new node with previous, next and element all set to null.
      protected AbstractLinkedList.Node<E> createNode​(E value)
      Deprecated.
      Creates a new node with the specified properties.
      protected java.util.Iterator<E> createSubListIterator​(AbstractLinkedList.LinkedSubList<E> subList)
      Deprecated.
      Creates an iterator for the sublist.
      protected java.util.ListIterator<E> createSubListListIterator​(AbstractLinkedList.LinkedSubList<E> subList, int fromIndex)
      Deprecated.
      Creates a list iterator for the sublist.
      protected void doReadObject​(java.io.ObjectInputStream inputStream)
      Deprecated.
      Deserializes the data held in this object to the stream specified.
      protected void doWriteObject​(java.io.ObjectOutputStream outputStream)
      Deprecated.
      Serializes the data held in this object to the stream specified.
      boolean equals​(java.lang.Object obj)
      Deprecated.
       
      E get​(int index)
      Deprecated.
       
      E getFirst()
      Deprecated.
      Gets the first element.
      E getLast()
      Deprecated.
      Gets the last element.
      protected AbstractLinkedList.Node<E> getNode​(int index, boolean endMarkerAllowed)
      Deprecated.
      Gets the node at a particular index.
      int hashCode()
      Deprecated.
       
      int indexOf​(java.lang.Object value)
      Deprecated.
       
      protected void init()
      Deprecated.
      The equivalent of a default constructor, broken out so it can be called by any constructor and by readObject.
      boolean isEmpty()
      Deprecated.
       
      protected boolean isEqualValue​(java.lang.Object value1, java.lang.Object value2)
      Deprecated.
      Compares two values for equals.
      java.util.Iterator<E> iterator()
      Deprecated.
       
      int lastIndexOf​(java.lang.Object value)
      Deprecated.
       
      java.util.ListIterator<E> listIterator()
      Deprecated.
       
      java.util.ListIterator<E> listIterator​(int fromIndex)
      Deprecated.
       
      E remove​(int index)
      Deprecated.
       
      boolean remove​(java.lang.Object value)
      Deprecated.
       
      boolean removeAll​(java.util.Collection<?> coll)
      Deprecated.
      protected void removeAllNodes()
      Deprecated.
      Removes all nodes by resetting the circular list marker.
      E removeFirst()
      Deprecated.
      Removes the first element.
      E removeLast()
      Deprecated.
      Removes the last element.
      protected void removeNode​(AbstractLinkedList.Node<E> node)
      Deprecated.
      Removes the specified node from the list.
      boolean retainAll​(java.util.Collection<?> coll)
      Deprecated.
      E set​(int index, E value)
      Deprecated.
       
      int size()
      Deprecated.
       
      java.util.List<E> subList​(int fromIndexInclusive, int toIndexExclusive)
      Deprecated.
      Gets a sublist of the main list.
      java.lang.Object[] toArray()
      Deprecated.
       
      <T> T[] toArray​(T[] array)
      Deprecated.
       
      java.lang.String toString()
      Deprecated.
       
      protected void updateNode​(AbstractLinkedList.Node<E> node, E value)
      Deprecated.
      Updates the node with a new value.
      • Methods inherited from class java.lang.Object

        clone, finalize, getClass, notify, notifyAll, wait, wait, wait
      • Methods inherited from interface java.util.Collection

        parallelStream, removeIf, stream, toArray
      • Methods inherited from interface java.lang.Iterable

        forEach
      • Methods inherited from interface java.util.List

        replaceAll, sort, spliterator
    • Constructor Detail

      • AbstractLinkedList

        protected AbstractLinkedList()
        Deprecated.
        Constructor that does nothing (intended for deserialization).

        If this constructor is used by a serializable subclass then the init() method must be called.

      • AbstractLinkedList

        protected AbstractLinkedList​(java.util.Collection<? extends E> coll)
        Deprecated.
        Constructs a list copying data from the specified collection.
        Parameters:
        coll - the collection to copy
    • Method Detail

      • add

        public boolean add​(E value)
        Deprecated.
        Specified by:
        add in interface java.util.Collection<E>
        Specified by:
        add in interface java.util.List<E>
      • add

        public void add​(int index,
                        E value)
        Deprecated.
        Specified by:
        add in interface java.util.List<E>
      • addAll

        public boolean addAll​(java.util.Collection<? extends E> coll)
        Deprecated.
        Specified by:
        addAll in interface java.util.Collection<E>
        Specified by:
        addAll in interface java.util.List<E>
      • addAll

        public boolean addAll​(int index,
                              java.util.Collection<? extends E> coll)
        Deprecated.
        Specified by:
        addAll in interface java.util.List<E>
      • addFirst

        public boolean addFirst​(E e)
        Deprecated.
        Adds an element at the beginning.
        Parameters:
        e - the element to beginning.
        Returns:
        true.
      • addLast

        public boolean addLast​(E e)
        Deprecated.
        Adds an element at the end.
        Parameters:
        e - the element to add.
        Returns:
        true.
      • addNode

        protected void addNode​(AbstractLinkedList.Node<E> nodeToInsert,
                               AbstractLinkedList.Node<E> insertBeforeNode)
        Deprecated.
        Inserts a new node into the list.
        Parameters:
        nodeToInsert - new node to insert
        insertBeforeNode - node to insert before
        Throws:
        java.lang.NullPointerException - if either node is null
      • clear

        public void clear()
        Deprecated.
        Specified by:
        clear in interface java.util.Collection<E>
        Specified by:
        clear in interface java.util.List<E>
      • contains

        public boolean contains​(java.lang.Object value)
        Deprecated.
        Specified by:
        contains in interface java.util.Collection<E>
        Specified by:
        contains in interface java.util.List<E>
      • containsAll

        public boolean containsAll​(java.util.Collection<?> coll)
        Deprecated.
        Specified by:
        containsAll in interface java.util.Collection<E>
        Specified by:
        containsAll in interface java.util.List<E>
      • createHeaderNode

        protected AbstractLinkedList.Node<EcreateHeaderNode()
        Deprecated.
        Creates a new node with previous, next and element all set to null. This implementation creates a new empty Node. Subclasses can override this to create a different class.
        Returns:
        newly created node
      • createNode

        protected AbstractLinkedList.Node<EcreateNode​(E value)
        Deprecated.
        Creates a new node with the specified properties. This implementation creates a new Node with data. Subclasses can override this to create a different class.
        Parameters:
        value - value of the new node
        Returns:
        a new node containing the value
      • createSubListIterator

        protected java.util.Iterator<EcreateSubListIterator​(AbstractLinkedList.LinkedSubList<E> subList)
        Deprecated.
        Creates an iterator for the sublist.
        Parameters:
        subList - the sublist to get an iterator for
        Returns:
        a new iterator on the given sublist
      • createSubListListIterator

        protected java.util.ListIterator<EcreateSubListListIterator​(AbstractLinkedList.LinkedSubList<E> subList,
                                                                      int fromIndex)
        Deprecated.
        Creates a list iterator for the sublist.
        Parameters:
        subList - the sublist to get an iterator for
        fromIndex - the index to start from, relative to the sublist
        Returns:
        a new list iterator on the given sublist
      • doReadObject

        protected void doReadObject​(java.io.ObjectInputStream inputStream)
                             throws java.io.IOException,
                                    java.lang.ClassNotFoundException
        Deprecated.
        Deserializes the data held in this object to the stream specified.

        The first serializable subclass must call this method from readObject.

        Parameters:
        inputStream - the stream to read the object from
        Throws:
        java.io.IOException - if any error occurs while reading from the stream
        java.lang.ClassNotFoundException - if a class read from the stream cannot be loaded
      • doWriteObject

        protected void doWriteObject​(java.io.ObjectOutputStream outputStream)
                              throws java.io.IOException
        Deprecated.
        Serializes the data held in this object to the stream specified.

        The first serializable subclass must call this method from writeObject.

        Parameters:
        outputStream - the stream to write the object to
        Throws:
        java.io.IOException - if anything goes wrong
      • equals

        public boolean equals​(java.lang.Object obj)
        Deprecated.
        Specified by:
        equals in interface java.util.Collection<E>
        Specified by:
        equals in interface java.util.List<E>
        Overrides:
        equals in class java.lang.Object
      • get

        public E get​(int index)
        Deprecated.
        Specified by:
        get in interface java.util.List<E>
      • getFirst

        public E getFirst()
        Deprecated.
        Gets the first element.
        Returns:
        the first element.
      • getLast

        public E getLast()
        Deprecated.
        Gets the last element.
        Returns:
        the last element.
      • getNode

        protected AbstractLinkedList.Node<EgetNode​(int index,
                                                     boolean endMarkerAllowed)
                                              throws java.lang.IndexOutOfBoundsException
        Deprecated.
        Gets the node at a particular index.
        Parameters:
        index - the index, starting from 0
        endMarkerAllowed - whether or not the end marker can be returned if startIndex is set to the list's size
        Returns:
        the node at the given index
        Throws:
        java.lang.IndexOutOfBoundsException - if the index is less than 0; equal to the size of the list and endMakerAllowed is false; or greater than the size of the list
      • hashCode

        public int hashCode()
        Deprecated.
        Specified by:
        hashCode in interface java.util.Collection<E>
        Specified by:
        hashCode in interface java.util.List<E>
        Overrides:
        hashCode in class java.lang.Object
      • indexOf

        public int indexOf​(java.lang.Object value)
        Deprecated.
        Specified by:
        indexOf in interface java.util.List<E>
      • init

        protected void init()
        Deprecated.
        The equivalent of a default constructor, broken out so it can be called by any constructor and by readObject. Subclasses which override this method should make sure they call super, so the list is initialized properly.
      • isEmpty

        public boolean isEmpty()
        Deprecated.
        Specified by:
        isEmpty in interface java.util.Collection<E>
        Specified by:
        isEmpty in interface java.util.List<E>
      • isEqualValue

        protected boolean isEqualValue​(java.lang.Object value1,
                                       java.lang.Object value2)
        Deprecated.
        Compares two values for equals. This implementation uses the equals method. Subclasses can override this to match differently.
        Parameters:
        value1 - the first value to compare, may be null
        value2 - the second value to compare, may be null
        Returns:
        true if equal
      • iterator

        public java.util.Iterator<Eiterator()
        Deprecated.
        Specified by:
        iterator in interface java.util.Collection<E>
        Specified by:
        iterator in interface java.lang.Iterable<E>
        Specified by:
        iterator in interface java.util.List<E>
      • lastIndexOf

        public int lastIndexOf​(java.lang.Object value)
        Deprecated.
        Specified by:
        lastIndexOf in interface java.util.List<E>
      • listIterator

        public java.util.ListIterator<ElistIterator()
        Deprecated.
        Specified by:
        listIterator in interface java.util.List<E>
      • listIterator

        public java.util.ListIterator<ElistIterator​(int fromIndex)
        Deprecated.
        Specified by:
        listIterator in interface java.util.List<E>
      • remove

        public E remove​(int index)
        Deprecated.
        Specified by:
        remove in interface java.util.List<E>
      • remove

        public boolean remove​(java.lang.Object value)
        Deprecated.
        Specified by:
        remove in interface java.util.Collection<E>
        Specified by:
        remove in interface java.util.List<E>
      • removeAll

        public boolean removeAll​(java.util.Collection<?> coll)
        Deprecated.

        This implementation iterates over the elements of this list, checking each element in turn to see if it's contained in coll. If it's contained, it's removed from this list. As a consequence, it is advised to use a collection type for coll that provides a fast (for example O(1)) implementation of Collection.contains(Object).

        Specified by:
        removeAll in interface java.util.Collection<E>
        Specified by:
        removeAll in interface java.util.List<E>
      • removeAllNodes

        protected void removeAllNodes()
        Deprecated.
        Removes all nodes by resetting the circular list marker.
      • removeFirst

        public E removeFirst()
        Deprecated.
        Removes the first element.
        Returns:
        The value removed.
      • removeLast

        public E removeLast()
        Deprecated.
        Removes the last element.
        Returns:
        The value removed.
      • removeNode

        protected void removeNode​(AbstractLinkedList.Node<E> node)
        Deprecated.
        Removes the specified node from the list.
        Parameters:
        node - the node to remove
        Throws:
        java.lang.NullPointerException - if node is null
      • retainAll

        public boolean retainAll​(java.util.Collection<?> coll)
        Deprecated.

        This implementation iterates over the elements of this list, checking each element in turn to see if it's contained in coll. If it's not contained, it's removed from this list. As a consequence, it is advised to use a collection type for coll that provides a fast (for example O(1)) implementation of Collection.contains(Object).

        Specified by:
        retainAll in interface java.util.Collection<E>
        Specified by:
        retainAll in interface java.util.List<E>
      • set

        public E set​(int index,
                     E value)
        Deprecated.
        Specified by:
        set in interface java.util.List<E>
      • size

        public int size()
        Deprecated.
        Specified by:
        size in interface java.util.Collection<E>
        Specified by:
        size in interface java.util.List<E>
      • subList

        public java.util.List<EsubList​(int fromIndexInclusive,
                                         int toIndexExclusive)
        Deprecated.
        Gets a sublist of the main list.
        Specified by:
        subList in interface java.util.List<E>
        Parameters:
        fromIndexInclusive - the index to start from
        toIndexExclusive - the index to end at
        Returns:
        the new sublist
      • toArray

        public java.lang.Object[] toArray()
        Deprecated.
        Specified by:
        toArray in interface java.util.Collection<E>
        Specified by:
        toArray in interface java.util.List<E>
      • toArray

        public <T> T[] toArray​(T[] array)
        Deprecated.
        Specified by:
        toArray in interface java.util.Collection<E>
        Specified by:
        toArray in interface java.util.List<E>
      • toString

        public java.lang.String toString()
        Deprecated.
        Overrides:
        toString in class java.lang.Object
      • updateNode

        protected void updateNode​(AbstractLinkedList.Node<E> node,
                                  E value)
        Deprecated.
        Updates the node with a new value. This implementation sets the value on the node. Subclasses can override this to record the change.
        Parameters:
        node - node to update
        value - new value of the node