Массивы
Для хранения упорядоченных коллекций существует особая структура данных, которая называется массив Array
.
Массив
- упорядоченная коллекция данных, в которой присутствуют 1-й, 2-й, 3-й элементы и т.д. Например, она понадобится нам для хранения списка чего-либо: пользователей, товаров, элементов сайта и т.д.
Видео
Создание
Существует два 2️⃣ варианта для создания пустого массива:
let arr = new Array(5)
// new Array(5) - создаёт массив без элементов (к которым просто так нельзя обратится), но с заданной длиной.
let arr = []
Практически всегда используется второй вариант 2️⃣ синтаксиса . В скобках мы можем указать начальные значения элементов:
Элементы массива нумеруются, начиная с нуля 0️⃣ .
Мы можем получить элемент, указав его номер в квадратных скобках :
Мы можем заменить элемент:
fruits[2] = 'Груша' // теперь ["Яблоко", "Апельсин", "Груша"]
…Или добавить новый к существующему массиву :
length
Общее число элементов массива содержится в его свойстве .length
:
Свойство length
автоматически обновляется при изменении массива. Если быть точными, это не количество элементов массива, а наибольший цифровой индекс плюс один.
Например, единственный реальный элемент, имеющий большой индекс, даёт наибольшую возможную длину массиву :
Обратите внимание, что обычно мы не используем массивы таким образом.
Ещё один интересный факт о свойстве length
– его можно перезаписать.
Если мы вручную увеличим ➕ его, ничего интересного не произойдёт. Зато, если мы уменьшим➖ его, массив станет короче. Этот процесс необратим, как мы можем понять из примера :
Таким образом, самый простой способ очистить массив – это arr.length = 0
.
Типы элементов
В массиве могут храниться элементы любого типа - число, булевое значение, строки, объекты или целые функции⚙️:
Например :
Обратите внимание result1 = arr[3]
содержить текст функции⚙️, а result2 = arr[3]()
результат выполненной функции⚙️ - ()
мы её запускаем.
Методы push/pop
Стек
- вариант применения массивов как структуры данных.
Она поддерживает два 2️⃣ вида операций:
push
добавляет ➕ элемент в конец.
pop
удаляет ➖ последний элемент.
Таким образом, новые элементы всегда добавляются или удаляются из "конца".
Примером стека обычно служит пирамидка: новые кольца кладутся наверх и берутся тоже сверху.
Очередь
– один из самых распространённых вариантов применения массива. В области компьютерных ️ наук так называется упорядоченная коллекция элементов
Методы работы с концом массива:
push
Добавляет ➕ элемент в конец массива :
pop
Удаляет ➖ последний элемент из массива и возвращает его :
Методы работы с началом массива:
shift
Удаляет ➖ из массива первый и возвращает его:
unshift
Добавляет ➕ элемент в начало массива:
Методы push
и unshift
могут добавлять ➕ сразу несколько элементов :
Внутреннее устройство массива
Массив – это особый подвид объектов. Квадратные скобки, используемые для того, чтобы получить доступ к свойству arr[0]
– это по сути обычный синтаксис доступа по ключу, как obj[key],
где в роли obj
у нас arr
, а в качестве ключа – числовой индекс.
Массивы расширяют объекты, так как предусматривают специальные методы для работы с упорядоченными коллекциями данных, а также свойство length.
Но в основе всё равно лежит объект.
Следует помнить, что в JavaScript массив является объектом и, следовательно, ведёт себя как объект.
Например, массив копируется по ссылке :
Что действительно делает массивы особенными – это их внутреннее представление. Движок JavaScript старается хранить элементы массива в непрерывной области памяти, один за другим. Существуют и другие способы оптимизации, благодаря которым массивы работают очень быстро.
Но все они утратят эффективность, если мы перестанем работать с массивом как с "упорядоченной коллекцией данных" и начнём использовать его как обычный объект.
Например, технически мы можем сделать следующее:
let fruits = [] // создаём пустой массив
fruits[99999] = 5 // создаём свойство с избыточным индексом, намного превышающим необходимую длину массива
fruits.age = 25 // создаём свойство с произвольным именем
Это возможно, потому что в основе массива лежит объект. Мы можем присвоить ему любые свойства.
- Добавление нечислового свойства (индекса test), например: arr.test = 5
- Создание «дыр», например: добавление arr[0], затем arr[1000] (между ними ничего нет)
- Заполнение массива в обратном порядке, например: arr[1000], arr[999] и т.д.
Массив следует считать особой структурой, позволяющей работать с упорядоченными данными. Если вам нужны произвольные ключи, вполне возможно, лучше подойдёт обычный объект {}.
Эффективность
Методы push/pop
выполняются быстро, а методы shift/unshift
– медленно.
Почему работать с концом массива быстрее, чем с его началом? Давайте посмотрим, что происходит во время выполнения:
fruits.shift() // удаляем первый элемент с начала
Просто взять и удалить элемент с номером 0 недостаточно. Нужно также заново пронумеровать остальные элементы.
Операция shift
должна выполнить 3 действия:
- Удалить элемент с индексом 0
- Сдвинуть все элементы влево, заново пронумеровать их, заменив
1
на0
,2
на1
и т.д.
- Обновить свойство
length
Чем больше элементов содержит массив, тем больше времени потребуется для того, чтобы их переместить, больше операций с памятью.
А что же с удалением pop
? Ему не нужно ничего перемещать. Чтобы удалить элемент в конце массива, метод pop
очищает индекс и уменьшает значение length
. Остальные элементы остаются с теми же индексами.
fruits.pop() // удаляем один элемент с конца
Метод pop
не требует перемещения. Именно поэтому он выполняется очень быстро.
Аналогично работает метод push
.
Перебор элементов
Одним из самых старых способов перебора элементов массива является цикл for( )
по цифровым индексам :
Но для массивов возможен и другой вариант цикла, for..of
:
Цикл for..of
не предоставляет доступа к номеру текущего элемента, только к его значению, но в большинстве случаев этого более чем достаточно, а также это короче.
Многомерные массивы
Массивы могут содержать элементы, которые тоже являются массивами. Это можно использовать для создания многомерных массивов, например, для хранения матриц:
Итого
Массив – это особый тип объекта, предназначенный для работы с упорядоченным набором элементов.
Объявление:
// квадратные скобки (обычно)
let arr = [item1, item2...]
// new Array (очень редко)
let arr = new Array(item1, item2...)
Вызов new Array(number)
создаёт массив с заданной длиной, но без элементов.
Свойство length
отражает длину массива.
Мы можем использовать массив как двустороннюю очередь, используя следующие операции:
push(...items)
добавляет ➕ items в конец массива.pop()
удаляет ➖элемент в конце массива и возвращает его.shift()
удаляет ➖ элемент в начале массива и возвращает его.unshift(...items)
добавляет ➕ items в начало массива.
Чтобы перебрать элементы массива:
for (let i=0 i<arr.length i++)
– работает быстрее всего, совместим со старыми браузерами.for (let item of arr)
– современный синтаксис только для значений элементов (к индексам нет доступа).for (let i in arr)
– никогда не используйте для массивов!
React Native
React Native предоставляет набор компонентов для представления списков данных. Как правило, вам нужно использовать либо FlatList
, либо SectionList
. Детальней с ними мы познакомимся позже, главное сейчас вам понять, что на вход они принимают массив, который рендерит на экране.
Проблемы?
Пишите в Telegram или ВКонтакте, а также подписывайтесь на наши новости
Вопросы
Массив – это ...
- Подвид объектов с "упорядоченной коллекцией данных"
- Внутренная функция
- Подвид объектов с "не упорядоченной коллекцией данных"
Пустой массив создается:
let arr2 = { }
let arr1 = [ ]
let arr3 = ( )
Длину массива можно определить свойством:
pop
push
length
В массиве могут храниться элементы:
- Любого типа
- Числовые
- Строковые
Добавление элемента в конце массива:
push
pop
shift
Удаление элемента в начале массива:
pop
shift
unshift
____ в массиве - это число, представляющее позицию любого заданного элемента в массиве.
- индекс
- длина
- функция
Какое значение следует поместить в квадратные скобки, чтобы получить первый элемент в массиве? \n myArray[]
0
1
2
Использование метода .pop()
для массива будет ___ и ___ последний элемент массива.
- "удалять / возвращать"
- "возвращать / удалять"
Для того чтобы понять, на сколько вы усвоили этот урок, пройдите тест в мобильном приложении нашей школы по этой теме или в нашем телеграм боте.
Ссылки
- Статья "Массивы"
- MDN web doc. Статья "Массивы"
- Статья "JavaScript массивы"
- Код для подростков: прекрасное руководство по программированию для начинающих, том 1: Javascript - Jeremy Moritz
Contributors ✨
Thanks goes to these wonderful people (emoji key):
Dmitriy K. | Dmitriy Vasilev 💵 | Resoner2005 🐛 🎨 🖋 | Navernoss 🖋 🐛 🎨 |