1 /*
2  *  Licensed to the Apache Software Foundation (ASF) under one or more
3  *  contributor license agreements.  See the NOTICE file distributed with
4  *  this work for additional information regarding copyright ownership.
5  *  The ASF licenses this file to You under the Apache License, Version 2.0
6  *  (the "License"); you may not use this file except in compliance with
7  *  the License.  You may obtain a copy of the License at
8  *
9  *     http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *  Unless required by applicable law or agreed to in writing, software
12  *  distributed under the License is distributed on an "AS IS" BASIS,
13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *  See the License for the specific language governing permissions and
15  *  limitations under the License.
16  */
17 
18 package java.util;
19 
20 
21 /**
22  * A {@code List} is a collection which maintains an ordering for its elements. Every
23  * element in the {@code List} has an index. Each element can thus be accessed by its
24  * index, with the first index being zero. Normally, {@code List}s allow duplicate
25  * elements, as compared to Sets, where elements have to be unique.
26  */
27 public interface List<E> extends Collection<E> {
28     /**
29      * Inserts the specified object into this {@code List} at the specified location.
30      * The object is inserted before the current element at the specified
31      * location. If the location is equal to the size of this {@code List}, the object
32      * is added at the end. If the location is smaller than the size of this
33      * {@code List}, then all elements beyond the specified location are moved by one
34      * position towards the end of the {@code List}.
35      *
36      * @param location
37      *            the index at which to insert.
38      * @param object
39      *            the object to add.
40      * @throws UnsupportedOperationException
41      *                if adding to this {@code List} is not supported.
42      * @throws ClassCastException
43      *                if the class of the object is inappropriate for this
44      *                {@code List}.
45      * @throws IllegalArgumentException
46      *                if the object cannot be added to this {@code List}.
47      * @throws IndexOutOfBoundsException
48      *                if {@code location < 0 || location > size()}
49      */
add(int location, E object)50     public void add(int location, E object);
51 
52     /**
53      * Adds the specified object at the end of this {@code List}.
54      *
55      * @param object
56      *            the object to add.
57      * @return always true.
58      * @throws UnsupportedOperationException
59      *                if adding to this {@code List} is not supported.
60      * @throws ClassCastException
61      *                if the class of the object is inappropriate for this
62      *                {@code List}.
63      * @throws IllegalArgumentException
64      *                if the object cannot be added to this {@code List}.
65      */
add(E object)66     public boolean add(E object);
67 
68     /**
69      * Inserts the objects in the specified collection at the specified location
70      * in this {@code List}. The objects are added in the order they are returned from
71      * the collection's iterator.
72      *
73      * @param location
74      *            the index at which to insert.
75      * @param collection
76      *            the collection of objects to be inserted.
77      * @return true if this {@code List} has been modified through the insertion, false
78      *         otherwise (i.e. if the passed collection was empty).
79      * @throws UnsupportedOperationException
80      *                if adding to this {@code List} is not supported.
81      * @throws ClassCastException
82      *                if the class of an object is inappropriate for this
83      *                {@code List}.
84      * @throws IllegalArgumentException
85      *                if an object cannot be added to this {@code List}.
86      * @throws IndexOutOfBoundsException
87      *                if {@code location < 0 || location > size()}
88      */
addAll(int location, Collection<? extends E> collection)89     public boolean addAll(int location, Collection<? extends E> collection);
90 
91     /**
92      * Adds the objects in the specified collection to the end of this {@code List}. The
93      * objects are added in the order in which they are returned from the
94      * collection's iterator.
95      *
96      * @param collection
97      *            the collection of objects.
98      * @return {@code true} if this {@code List} is modified, {@code false} otherwise
99      *         (i.e. if the passed collection was empty).
100      * @throws UnsupportedOperationException
101      *                if adding to this {@code List} is not supported.
102      * @throws ClassCastException
103      *                if the class of an object is inappropriate for this
104      *                {@code List}.
105      * @throws IllegalArgumentException
106      *                if an object cannot be added to this {@code List}.
107      */
addAll(Collection<? extends E> collection)108     public boolean addAll(Collection<? extends E> collection);
109 
110     /**
111      * Removes all elements from this {@code List}, leaving it empty.
112      *
113      * @throws UnsupportedOperationException
114      *                if removing from this {@code List} is not supported.
115      * @see #isEmpty
116      * @see #size
117      */
clear()118     public void clear();
119 
120     /**
121      * Tests whether this {@code List} contains the specified object.
122      *
123      * @param object
124      *            the object to search for.
125      * @return {@code true} if object is an element of this {@code List}, {@code false}
126      *         otherwise
127      */
contains(Object object)128     public boolean contains(Object object);
129 
130     /**
131      * Tests whether this {@code List} contains all objects contained in the
132      * specified collection.
133      *
134      * @param collection
135      *            the collection of objects
136      * @return {@code true} if all objects in the specified collection are
137      *         elements of this {@code List}, {@code false} otherwise.
138      */
containsAll(Collection<?> collection)139     public boolean containsAll(Collection<?> collection);
140 
141     /**
142      * Compares the given object with the {@code List}, and returns true if they
143      * represent the <em>same</em> object using a class specific comparison. For
144      * {@code List}s, this means that they contain the same elements in exactly the same
145      * order.
146      *
147      * @param object
148      *            the object to compare with this object.
149      * @return boolean {@code true} if the object is the same as this object,
150      *         and {@code false} if it is different from this object.
151      * @see #hashCode
152      */
equals(Object object)153     public boolean equals(Object object);
154 
155     /**
156      * Returns the element at the specified location in this {@code List}.
157      *
158      * @param location
159      *            the index of the element to return.
160      * @return the element at the specified location.
161      * @throws IndexOutOfBoundsException
162      *                if {@code location < 0 || location >= size()}
163      */
get(int location)164     public E get(int location);
165 
166     /**
167      * Returns the hash code for this {@code List}. It is calculated by taking each
168      * element' hashcode and its position in the {@code List} into account.
169      *
170      * @return the hash code of the {@code List}.
171      */
hashCode()172     public int hashCode();
173 
174     /**
175      * Searches this {@code List} for the specified object and returns the index of the
176      * first occurrence.
177      *
178      * @param object
179      *            the object to search for.
180      * @return the index of the first occurrence of the object or -1 if the
181      *         object was not found.
182      */
indexOf(Object object)183     public int indexOf(Object object);
184 
185     /**
186      * Returns whether this {@code List} contains no elements.
187      *
188      * @return {@code true} if this {@code List} has no elements, {@code false}
189      *         otherwise.
190      * @see #size
191      */
isEmpty()192     public boolean isEmpty();
193 
194     /**
195      * Returns an iterator on the elements of this {@code List}. The elements are
196      * iterated in the same order as they occur in the {@code List}.
197      *
198      * @return an iterator on the elements of this {@code List}.
199      * @see Iterator
200      */
iterator()201     public Iterator<E> iterator();
202 
203     /**
204      * Searches this {@code List} for the specified object and returns the index of the
205      * last occurrence.
206      *
207      * @param object
208      *            the object to search for.
209      * @return the index of the last occurrence of the object, or -1 if the
210      *         object was not found.
211      */
lastIndexOf(Object object)212     public int lastIndexOf(Object object);
213 
214     /**
215      * Returns a {@code List} iterator on the elements of this {@code List}. The elements are
216      * iterated in the same order that they occur in the {@code List}.
217      *
218      * @return a {@code List} iterator on the elements of this {@code List}
219      *
220      * @see ListIterator
221      */
listIterator()222     public ListIterator<E> listIterator();
223 
224     /**
225      * Returns a list iterator on the elements of this {@code List}. The elements are
226      * iterated in the same order as they occur in the {@code List}. The iteration
227      * starts at the specified location.
228      *
229      * @param location
230      *            the index at which to start the iteration.
231      * @return a list iterator on the elements of this {@code List}.
232      * @throws IndexOutOfBoundsException
233      *                if {@code location < 0 || location > size()}
234      * @see ListIterator
235      */
listIterator(int location)236     public ListIterator<E> listIterator(int location);
237 
238     /**
239      * Removes the object at the specified location from this {@code List}.
240      *
241      * @param location
242      *            the index of the object to remove.
243      * @return the removed object.
244      * @throws UnsupportedOperationException
245      *                if removing from this {@code List} is not supported.
246      * @throws IndexOutOfBoundsException
247      *                if {@code location < 0 || location >= size()}
248      */
remove(int location)249     public E remove(int location);
250 
251     /**
252      * Removes the first occurrence of the specified object from this {@code List}.
253      *
254      * @param object
255      *            the object to remove.
256      * @return true if this {@code List} was modified by this operation, false
257      *         otherwise.
258      * @throws UnsupportedOperationException
259      *                if removing from this {@code List} is not supported.
260      */
remove(Object object)261     public boolean remove(Object object);
262 
263     /**
264      * Removes all occurrences in this {@code List} of each object in the specified
265      * collection.
266      *
267      * @param collection
268      *            the collection of objects to remove.
269      * @return {@code true} if this {@code List} is modified, {@code false} otherwise.
270      * @throws UnsupportedOperationException
271      *                if removing from this {@code List} is not supported.
272      */
removeAll(Collection<?> collection)273     public boolean removeAll(Collection<?> collection);
274 
275     /**
276      * Removes all objects from this {@code List} that are not contained in the
277      * specified collection.
278      *
279      * @param collection
280      *            the collection of objects to retain.
281      * @return {@code true} if this {@code List} is modified, {@code false} otherwise.
282      * @throws UnsupportedOperationException
283      *                if removing from this {@code List} is not supported.
284      */
retainAll(Collection<?> collection)285     public boolean retainAll(Collection<?> collection);
286 
287     /**
288      * Replaces the element at the specified location in this {@code List} with the
289      * specified object. This operation does not change the size of the {@code List}.
290      *
291      * @param location
292      *            the index at which to put the specified object.
293      * @param object
294      *            the object to insert.
295      * @return the previous element at the index.
296      * @throws UnsupportedOperationException
297      *                if replacing elements in this {@code List} is not supported.
298      * @throws ClassCastException
299      *                if the class of an object is inappropriate for this
300      *                {@code List}.
301      * @throws IllegalArgumentException
302      *                if an object cannot be added to this {@code List}.
303      * @throws IndexOutOfBoundsException
304      *                if {@code location < 0 || location >= size()}
305      */
set(int location, E object)306     public E set(int location, E object);
307 
308     /**
309      * Returns the number of elements in this {@code List}.
310      *
311      * @return the number of elements in this {@code List}.
312      */
size()313     public int size();
314 
315     /**
316      * Returns a {@code List} of the specified portion of this {@code List} from the given start
317      * index to the end index minus one. The returned {@code List} is backed by this
318      * {@code List} so changes to it are reflected by the other.
319      *
320      * @param start
321      *            the index at which to start the sublist.
322      * @param end
323      *            the index one past the end of the sublist.
324      * @return a list of a portion of this {@code List}.
325      * @throws IndexOutOfBoundsException
326      *                if {@code start < 0, start > end} or {@code end >
327      *                size()}
328      */
subList(int start, int end)329     public List<E> subList(int start, int end);
330 
331     /**
332      * Returns an array containing all elements contained in this {@code List}.
333      *
334      * @return an array of the elements from this {@code List}.
335      */
toArray()336     public Object[] toArray();
337 
338     /**
339      * Returns an array containing all elements contained in this {@code List}. If the
340      * specified array is large enough to hold the elements, the specified array
341      * is used, otherwise an array of the same type is created. If the specified
342      * array is used and is larger than this {@code List}, the array element following
343      * the collection elements is set to null.
344      *
345      * @param array
346      *            the array.
347      * @return an array of the elements from this {@code List}.
348      * @throws ArrayStoreException
349      *                if the type of an element in this {@code List} cannot be stored
350      *                in the type of the specified array.
351      */
toArray(T[] array)352     public <T> T[] toArray(T[] array);
353 }
354