Over a million developers have joined DZone.

Removing Items From ArrayLists in Java 8

DZone's Guide to

Removing Items From ArrayLists in Java 8

Can Java 8 beat the usual cost of removing items from an ArrayList? Read on to find out and for some source code.

· Java Zone ·
Free Resource

Verify, standardize, and correct the Big 4 + more– name, email, phone and global addresses – try our Data Quality APIs now at Melissa Developer Portal!

As we know, ArrayList's implementation of the List interface stores elements in an Array under the hood. Removing elements from an ArrayList is a bit costly, which is on the order of n^2.

Let’s say I have a list of integers and I want to remove all the non-prime numbers from the list.

Typically, what we do is use iterator and a while loop to do that. We can’t iterate/remove at the same time with for each loops — we would end up with concurrent modification exceptions.


Iterator<Integer> iterator = numbers.iterator();
        while (iterator.hasNext()) {
            Integer next = iterator.next();
            if (!isPrime(next)) {

However, it has an order of n^2 complexity. We are doing two things here — iterating the entire list, which is n here. In the ArrayList, when you remove an element from an index, everything on the tail of the array has to be shoved up one space. That’s how the remove method works. It has to copy array data on each remove call. That means there are n copies. So it ends up being an order of n^2.

Java 8 has a removeIf method in the collection interface. For the ArrayList, it has an advanced implementation, which ends up being to the order of n.

numbers.removeIf(integer -> !isPrime(integer));

Here is the source code of the removeIf method from the Java 8 API:

    public boolean removeIf(Predicate<? super E> filter) {
        // figure out which elements are to be removed
        // any exception thrown from the filter predicate at this stage
        // will leave the collection unmodified
        int removeCount = 0;
        final BitSet removeSet = new BitSet(size);
        final int expectedModCount = modCount;
        final int size = this.size;
        for (int i=0; modCount == expectedModCount && i < size; i++) {
            final E element = (E) elementData[i];
            if (filter.test(element)) {
        if (modCount != expectedModCount) {
            throw new ConcurrentModificationException();

        // shift surviving elements left over the spaces left by removed elements
        final boolean anyToRemove = removeCount > 0;
        if (anyToRemove) {
            final int newSize = size - removeCount;
            for (int i=0, j=0; (i < size) && (j < newSize); i++, j++) {
                i = removeSet.nextClearBit(i);
                elementData[j] = elementData[i];
            for (int k=newSize; k < size; k++) {
                elementData[k] = null;  // Let gc do its work
            this.size = newSize;
            if (modCount != expectedModCount) {
                throw new ConcurrentModificationException();

        return anyToRemove;

Developers! Quickly and easily gain access to the tools and information you need! Explore, test and combine our data quality APIs at Melissa Developer Portal – home to tools that save time and boost revenue. 

concurrent ,arraylist ,java ,api

Published at DZone with permission of

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}