Home > Web Front-end > JS Tutorial > The 'Hole' Truth: Understanding JavaScript&#s Sparse Arrays and Unexpected Behaviors

The 'Hole' Truth: Understanding JavaScript&#s Sparse Arrays and Unexpected Behaviors

Barbara Streisand
Release: 2025-01-13 08:45:43
Original
448 people have browsed it

The

I was recently brushing up on my Data Structures and Algorithms skills, specifically, sorting algorithms; and I found myself in an interesting situation.

How do I create a random array of length n of values to test my sorting algorithm? You might say that's easy, and it truly is. In your head you probably came up with something like this:

function randomArray(n) {
    const arrToReturn = [];

    for (let i = 0; i < n; i++) {
        arrToReturn.push(Math.floor(Math.random() * 10));
    }
    return arrToReturn;
}

Copy after login

This definitely works as intended. But I was looking for something much simpler. Preferably a one-liner. Well, the first thought that came to mind was to use new Array().

const randomArray = (n) => new Array(n).map(() => Math.floor(Math.random() * 10));

console.log(randomArray(5))
Copy after login

What do you expect this to log?

Well, I was expecting this to log an array of random 5 values. If you weren't, then cheers! You know what I'm about to discuss :)

To my surprise, it's not the case. It logs this in Node 20:
[ <5 empty items> ]

Hmmm ... Puzzling!

Interestingly, console.log(randomArray(5).length) logs 5.

So, why does this happen? Well, let's talk about Sparse Arrays in Javascript!

Sparse Arrays

Sparse arrays are arrays containing one or more empty slots. For instance:

new Array(2)
// [<2 empty items>]

[1, , , 3]
// [1, <2 empty items>, 3]
Copy after login

So, how does this work?

Well, when you create an array in JS with new Array(5), it creates an array with 5 uninitialized slots. This means that they do not contain anything; not null, not undefined.

Okay, I get that! But can't you call .map on those "slots"?

Well, when you call iterative methods such as forEach, map, reduce, and filter, etc... on a sparse array, these empty slots are skipped.

Let's take a look at our function randomArray again.

const randomArray = (n) => new Array(n).map(() => Math.floor(Math.random() * 10));
Copy after login

We create an array of length n with new Array(n) which returns a sparse array [<5 empty items>]. Then we call map on that array. Since all the slots are empty, they all skipped. Hence, the result we got!

Why does calling .length on a sparse array return a value then?

This is due to the way .length array method is implemented in JS. To get the value of length, we take the largest index and just add 1. And since sparse arrays are indexed, we'll get the length value as expected. You can read more here.

Let's fix our buggy randomArray function above

Since sparse arrays contain empty or non-initialized slots, hence, not iterable, we can fix this by filling these slots with some values. We can achieve that by using the .fill array method:

const randomArray = (n) => new Array(n).fill().map(() => Math.floor(Math.random() * 10));

console.log(randomArray(5))
Copy after login

And now, we're good to go!

The above is the detailed content of The 'Hole' Truth: Understanding JavaScript&#s Sparse Arrays and Unexpected Behaviors. For more information, please follow other related articles on the PHP Chinese website!

source:dev.to
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template