LinkedList<E> class
A custom implementation of a doubly linked list that implements the standard List<E>
interface.
This LinkedList
provides all list operations such as insertion, removal, iteration,
indexing, and length tracking, but operates using linked nodes rather than a backing array.
β οΈ Note: While all List<E>
methods are implemented, operations like random access,
sort()
, or shuffle()
are inherently less efficient due to the sequential nature
of linked lists compared to array-based lists.
π¦ Example Usage:
final list = LinkedList<String>();
list.add('A');
list.add('B');
list.insert(1, 'X');
print(list); // [A, X, B]
print(list.length); // 3
print(list[2]); // B
Internally, this list is backed by _Node<E>
instances that link to their previous and next nodes.
This allows efficient insertion and deletion at both ends and in the middle.
Constructors
- LinkedList()
- Creates an empty linked list.
Properties
- first β E
-
The first element.
getter/setter pairoverride
- firstOrNull β T?
-
Available on Iterable<
The first element of this iterator, orT> , provided by the IterableExtensions extensionnull
if the iterable is empty.no setter - hashCode β int
-
The hash code for this object.
no setterinherited
-
indexed
β Iterable<
(int, T)> -
Available on Iterable<
Pairs of elements of the indices and elements of this iterable.T> , provided by the IterableExtensions extensionno setter - isEmpty β bool
-
Whether this collection has no elements.
no setteroverride
- isNotEmpty β bool
-
Whether this collection has at least one element.
no setteroverride
- isOneAKind β bool
-
Available on List<
Checks if all list data have same value.T> , provided by the ListExtensions extensionno setter -
iterator
β Iterator<
E> -
A new
Iterator
that allows iterating the elements of thisIterable
.no setteroverride - last β E
-
The last element.
getter/setter pairoverride
- lastOrNull β T?
-
Available on Iterable<
The last element of this iterable, orT> , provided by the IterableExtensions extensionnull
if the iterable is empty.no setter - length β int
-
The number of objects in this list.
getter/setter pairoverride
-
nonNulls
β Iterable<
T> -
Available on Iterable<
The non-T?> , provided by the NullableIterableExtensions extensionnull
elements of this iterable.no setter -
reversed
β Iterable<
E> -
An Iterable of the objects in this list in reverse order.
no setteroverride
- runtimeType β Type
-
A representation of the runtime type of the object.
no setterinherited
- single β E
-
Checks that this iterable has only one element, and returns that element.
no setteroverride
- singleOrNull β T?
-
Available on Iterable<
The single element of this iterator, orT> , provided by the IterableExtensions extensionnull
.no setter -
toJS
β JSArray<
T> -
Available on List<
Converts this List to a JSArray by either casting, unwrapping, or cloning the List.T> , provided by the ListToJSArray extensionno setter -
toJSProxyOrRef
β JSArray<
T> -
Available on List<
Converts this List to a JSArray by either casting, unwrapping, or proxying the List.T> , provided by the ListToJSArray extensionno setter -
wait
β Future<
List< T> > -
Available on Iterable<
Waits for futures in parallel.Future< , provided by the FutureIterable extensionT> >no setter
Methods
-
add(
E element) β void -
Adds
value
to the end of this list, extending the length by one.override -
addAll(
Iterable< E> iterable) β void -
Appends all objects of
iterable
to the end of this list.override -
addAllIf(
ConditionTester< T> condition, Iterable<T> items) β void -
Available on List<
Adds all items from another list to a list if a condition is met.T> , provided by the ListExtensions extension -
addIf(
ConditionTester< T> condition, T element) β void -
Available on List<
Adds an item to a list if a condition is met.T> , provided by the ListExtensions extension -
all(
ConditionTester< T> test) β bool -
Available on Iterable<
Checks whether all elements of this iterable satisfyT> , provided by the IterableExtension extensiontest
. -
any(
bool test(E element)) β bool -
Checks whether any element of this iterable satisfies
test
.override -
asMap(
) β Map< int, E> -
An unmodifiable Map view of this list.
override
-
asNameMap(
) β Map< String, T> -
Available on Iterable<
Creates a map from the names of enum values to the values.T> , provided by the EnumByName extension -
byName(
String name) β T -
Available on Iterable<
Finds the enum value in this list with nameT> , provided by the EnumByName extensionname
. -
cast<
R> () β List< R> -
Returns a view of this list as a list of
R
instances.override -
clear(
) β void -
Removes all objects from this list; the length of the list becomes zero.
override
-
contains(
Object? element) β bool -
Whether the collection contains an element equal to
element
.override -
elementAt(
int index) β E -
Returns the
index
th element.override -
elementAtOrNull(
int index) β T? -
Available on Iterable<
The element at positionT> , provided by the IterableExtensions extensionindex
of this iterable, ornull
. -
every(
bool test(E element)) β bool -
Checks whether every element of this iterable satisfies
test
.override -
expand<
T> (Iterable< T> toElements(E element)) β Iterable<T> -
Expands each element of this Iterable into zero or more elements.
override
-
fillRange(
int start, int end, [E? fillValue]) β void -
Overwrites a range of elements with
fillValue
.override -
filter(
ConditionTester< T> test) β Iterable<T> -
Available on Iterable<
Filters elements based on a predicate (alias forT> , provided by the IterableExtension extensionwhere
). -
filterWhere(
ConditionTester< T> test) β Iterable<T> -
Available on Iterable<
Filters elements based on a predicate.T> , provided by the IterableExtension extension -
find(
ConditionTester< T> test) β T? -
Available on Iterable<
Finds the first element that satisfies the given predicate.T> , provided by the IterableExtension extension -
findIndex(
ConditionTester< T> test) β int -
Available on Iterable<
Finds the index of the first element that satisfies the given predicate.T> , provided by the IterableExtension extension -
firstWhere(
bool test(E element), {E orElse()?}) β E -
The first element that satisfies the given predicate
test
.override -
firstWhereOrNull(
ConditionTester< T> test) β T? -
Available on Iterable<
Returns the first element that satisfies the predicate orT> , provided by the IterableExtension extensionnull
if none match. -
flatMap<
E> (Iterable< E> selector(T item)) β Iterable<E> -
Available on Iterable<
Flattens lists of items into a single iterable.T> , provided by the IterableExtension extension -
flatten<
E> (E? selector(T item)) β Iterable< E> -
Available on Iterable<
Transforms each element of the iterable into zero or more elements of typeT> , provided by the IterableExtension extensionE
and flattens the results. -
flattenIterable<
E> (Iterable< E> ? selector(T item)) β Iterable<E> -
Available on Iterable<
Transforms each element of the iterable into zero or more results of typeT> , provided by the IterableExtension extensionE
, and flattens the resulting collections into a single iterable. -
fold<
T> (T initialValue, T combine(T previousValue, E element)) β T -
Reduces a collection to a single value by iteratively combining each
element of the collection with an existing value
override
-
followedBy(
Iterable< E> other) β Iterable<E> -
Creates the lazy concatenation of this iterable and
other
.override -
forEach(
void action(E element)) β void -
Invokes
action
on each element of this iterable in iteration order.override -
get(
[int index = 0]) β T -
Available on Iterable<
Returns the element at the specified index.T> , provided by the IterableExtension extension -
getFirst(
) β T -
Available on Iterable<
Returns the first element of the iterable.T> , provided by the IterableExtension extension -
getLast(
) β T -
Available on Iterable<
Returns the last element of the iterable.T> , provided by the IterableExtension extension -
getRange(
int start, int end) β Iterable< E> -
Creates an Iterable that iterates over a range of elements.
override
-
group<
K> (K keySelector(T item)) β Map< K, List< T> > -
Available on Iterable<
Groups the elements of the iterable by a key returned from theT> , provided by the IterableExtension extensionkeySelector
function. -
groupBy<
K> (K keySelector(T item)) β Map< K, List< T> > -
Available on Iterable<
Groups elements of this iterable into a Map using the givenT> , provided by the IterableExtension extensionkeySelector
. -
groupByAndMap<
K, V> (K keySelector(T item), V valueSelector(T item)) β Map< K, List< V> > -
Available on Iterable<
Groups elements of this iterable into a Map usingT> , provided by the IterableExtension extensionkeySelector
, and appliesvalueSelector
to each element before storing it. -
indexOf(
Object? element, [int start = 0]) β int -
The first index of
element
in this list.override -
indexWhere(
bool test(E element), [int start = 0]) β int -
The first index in the list that satisfies the provided
test
.override -
indexWhereOrNull(
ConditionTester< T> test) β int? -
Available on Iterable<
Finds the index of an element that satisfies the predicate or returnsT> , provided by the IterableExtension extensionnull
if not found. -
insert(
int index, E element) β void -
Inserts
element
at positionindex
in this list.override -
insertAll(
int index, Iterable< E> iterable) β void -
Inserts all objects of
iterable
at positionindex
in this list.override -
isLengthBetween(
int min, int max) β bool -
Available on Iterable<
Checks if length of double value is BETWEEN minLength to max.T> , provided by the IterableExtension extension -
isLengthEqualTo(
int other) β bool -
Available on Iterable<
Checks if length of double value is EQUAL to max.T> , provided by the IterableExtension extension -
isLengthEt(
int max) β bool -
Available on Iterable<
Short form forT> , provided by the IterableExtension extensionisLengthEqualTo
-
isLengthGreaterThan(
int max) β bool -
Available on Iterable<
Checks if length of double value is GREATER than max.T> , provided by the IterableExtension extension -
isLengthGreaterThanOrEqualTo(
int max) β bool -
Available on Iterable<
Checks if length of double value is GREATER OR EQUAL to max.T> , provided by the IterableExtension extension -
isLengthGt(
int max) β bool -
Available on Iterable<
Short form forT> , provided by the IterableExtension extensionisLengthGreaterThan
-
isLengthGtEt(
int max) β bool -
Available on Iterable<
Short form forT> , provided by the IterableExtension extensionisLengthGreaterThanOrEqualTo
-
isLengthLessThan(
int max) β bool -
Available on Iterable<
Checks if length of double value is LESS than max.T> , provided by the IterableExtension extension -
isLengthLessThanOrEqualTo(
int max) β bool -
Available on Iterable<
Checks if length of double value is LESS OR EQUAL to max.T> , provided by the IterableExtension extension -
isLengthLt(
int max) β bool -
Available on Iterable<
Short form forT> , provided by the IterableExtension extensionisLengthLessThan
-
isLengthLtEt(
int max) β bool -
Available on Iterable<
Short form forT> , provided by the IterableExtension extensionisLengthLessThanOrEqualTo
-
join(
[String separator = ""]) β String -
Converts each element to a String and concatenates the strings.
override
-
lastIndexOf(
Object? element, [int? start]) β int -
The last index of
element
in this list.override -
lastIndexWhere(
bool test(E element), [int? start]) β int -
The last index in the list that satisfies the provided
test
.override -
lastWhere(
bool test(E element), {E orElse()?}) β E -
The last element that satisfies the given predicate
test
.override -
lastWhereOrNull(
ConditionTester< T> test) β T? -
Available on Iterable<
Returns the last element that satisfies the predicate orT> , provided by the IterableExtension extensionnull
if none match. -
map<
T> (T toElement(E e)) β Iterable< T> -
The current elements of this iterable modified by
toElement
.override -
none(
ConditionTester< T> test) β bool -
Available on Iterable<
Checks if no element matches the predicate.T> , provided by the IterableExtension extension -
noneMatch(
ConditionTester< T> test) β bool -
Available on Iterable<
Checks if none of the elements match a condition using noneMatch.T> , provided by the IterableExtension extension -
noSuchMethod(
Invocation invocation) β dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
pop(
) β T? -
Available on List<
Removes and returns the last element of the list.T> , provided by the ListExtensions extension -
process(
dynamic action(T item)) β void -
Available on Iterable<
Processes each element of the iterable using the providedT> , provided by the IterableExtension extensionaction
function. -
reduce(
E combine(E value, E element)) β E -
Reduces a collection to a single value by iteratively combining elements
of the collection using the provided function.
override
-
remove(
Object? value) β bool -
Removes the first occurrence of
value
from this list.override -
removeAllIf(
ConditionTester< T> condition, Iterable<T> items) β void -
Available on List<
Removes all items from another list if a condition is met.T> , provided by the ListExtensions extension -
removeAt(
int index) β E -
Removes the object at position
index
from this list.override -
removeIf(
ConditionTester< T> condition, T element) β void -
Available on List<
Removes an item from a list if a condition is met.T> , provided by the ListExtensions extension -
removeLast(
) β E -
Removes and returns the last object in this list.
override
-
removeRange(
int start, int end) β void -
Removes a range of elements from the list.
override
-
removeWhere(
bool test(E element)) β void -
Removes all objects from this list that satisfy
test
.override -
replaceRange(
int start, int end, Iterable< E> newContents) β void -
Replaces a range of elements with the elements of
replacements
.override -
retainWhere(
bool test(E element)) β void -
Removes all objects from this list that fail to satisfy
test
.override -
reverse(
) β List< T> -
Available on List<
Returns a new list with the elements in reverse order.T> , provided by the ListExtensions extension -
setAll(
int index, Iterable< E> iterable) β void -
Overwrites elements with the objects of
iterable
.override -
setRange(
int start, int end, Iterable< E> iterable, [int skipCount = 0]) β void -
Writes some elements of
iterable
into a range of this list.override -
shift(
) β T? -
Available on List<
Removes and returns the first element of the list.T> , provided by the ListExtensions extension -
shuffle(
[Random? random]) β void -
Shuffles the elements of this list randomly.
override
-
singleWhere(
bool test(E element), {E orElse()?}) β E -
The single element that satisfies
test
.override -
skip(
int count) β Iterable< E> -
Creates an Iterable that provides all but the first
count
elements.override -
skipWhile(
bool test(E value)) β Iterable< E> -
Creates an
Iterable
that skips leading elements whiletest
is satisfied.override -
sort(
[int compare(E a, E b)?]) β void -
Sorts this list according to the order specified by the
compare
function.override -
sortedByPublicFirst(
) β List< T> -
Available on Iterable<
Sorts declarations with public visibility before private ones.T> , provided by the SortByPublic extension -
sortedByPublicFirstThenSyntheticLast(
) β List< T> -
Available on Iterable<
Sorts declarations with public visibility first and synthetic declarations last.T> , provided by the SortByPublic extension -
stream(
) β GenericStream< T> -
Available on Iterable<
Converts the iterable to a stream.T> , provided by the IterableExtension extension -
sublist(
int start, [int? end]) β List< E> -
Returns a new list containing the elements between
start
andend
.override -
take(
int count) β Iterable< E> -
Creates a lazy iterable of the
count
first elements of this iterable.override -
takeWhile(
bool test(E value)) β Iterable< E> -
Creates a lazy iterable of the leading elements satisfying
test
.override -
toList(
{bool growable = true}) β List< E> -
Creates a List containing the elements of this Iterable.
override
-
toMap<
K, V> (K keySelector(T item), V valueSelector(T item)) β Map< K, V> -
Available on Iterable<
Maps the iterable to a new iterable using the providedT> , provided by the IterableExtension extensionmapper
function. -
toSet(
) β Set< E> -
Creates a Set containing the same elements as this iterable.
override
-
toString(
) β String -
A string representation of this object.
override
-
where(
bool test(E element)) β Iterable< E> -
Creates a new lazy Iterable with all elements that satisfy the
predicate
test
.override -
whereOrNull(
ConditionTester< T> test) β Iterable<T> ? -
Available on Iterable<
Returns an iterable with elements that match a condition, orT> , provided by the IterableExtension extensionnull
if none match. -
whereType<
T> () β Iterable< T> -
Creates a new lazy Iterable with all elements that have type
T
.override -
whereType<
U> () β Iterable< T> -
Available on Iterable<
Filters elements of a specific typeT> , provided by the IterableExtension extensionT
.
Operators
-
operator +(
List< E> other) β List<E> -
Returns the concatenation of this list and
other
.override -
operator ==(
Object other) β bool -
The equality operator.
inherited
-
operator [](
int index) β E -
The object at the given
index
in the list.override -
operator []=(
int index, E value) β void -
Sets the value at the given
index
in the list tovalue
.override