x.clear
# x равно []
8.1.16. Конкатенирование массивов и добавление в конец массива
Часто нужно добавить в конец существующего массива отдельный элемент или целый массив. В Ruby это можно сделать разными способами.
Оператор <<
добавляет объект в конец массива; в качестве значения он возвращает сам массив, поэтому можно объединять несколько таких операций в цепочку.
x = [1, 5, 9]
x << 13 # x равно [1, 5, 9, 13]
x << 17 << 21 # x равно [1, 5, 9, 13, 17, 21].
Аналогичную операцию выполняют методы unshift
и push
, которые добавляют элемент в начало и в конец массива соответственно (см. также следующий раздел данной главы).
Массивы можно конкатенировать методом concat
или с помощью операторов +
и +=
:
x = [1,2]
y = [3,4]
z = [5,6]
b = y + z # [3,4,5,6]
b += x # [3,4,5,6,1,2]
z.concat у # z равно [5,6,3,4]
Имейте в виду, что оператор +=
всегда создает новый объект. Также не забывайте, что оператор <<
добавляет в конец новый элемент, который сам может быть массивом.
a = [1,2]
b = [3,4]
a += b # [1,2,3,4]
a = [1,2]
b = [3,4]
а << b # [1,2, [3,4]]
a = [1,2]
b = [3,4]
а = a.concat(b) # [1,2,3,4]
8.1.17. Использование массива в качестве стека или очереди
Базовые операции со стеком называются push
и pop
, они добавляют и удаляют элементы в конец массива. Базовые операции с очередью — это shift
(удаляет элемент из начала массива) и unshift
(добавляет элемент в начало массива). Для добавления в конец массива можно также пользоваться оператором <<
(по существу синоним push
).
Постарайтесь не запутаться. Методы shift
и unshift
модифицируют массив в начале, a push
, pop
и <<
— в конце.
Эта тема будет продолжена в разделе 9.2.
8.1.18. Обход массива
Как и следовало ожидать, в классе Array
есть стандартный итератор each
. Но имеются и другие полезные итераторы.
Метод reverse_each
обходит массив в обратном порядке. Результат такой же, как если бы мы вызвали сначала метод reverse
, а потом each
, но работает быстрее.
words = %w(Son I am able she said)
str = ''
words.reverse_each { |W| str += '#{w} '}
# str равно 'said she able am I Son '
Если нужно только перебрать все индексы, можно воспользоваться итератором each_index
. Конструкция x.each_index
эквивалентна (0..(x.size- 1)).each
(то есть обходу всего диапазона индексов).
Итератор each_with_index
(подмешанный из модуля Comparable
) передает в блок как сам элемент, так и его индекс.
x = ['alpha', 'beta', 'gamma']
x.each_with_index do |x,i|
puts 'Элемент #{i} равен #{x}'
end
# Выводятся три строки.
Предположим, что нужно обойти массив в случайном порядке. Ниже представлен итератор random_each
(который просто вызывает метод randomize
, описанный в разделе 8.1.10).
class Array
# Предполагается, что метод randomize определен.
def random_each
temp = self.randomize
temp.each {|x| yield x}
end
end
dwarves = %w(Sleepy Dopey Happy Sneezy Grumpy Bashful Doc)
list = ''
dwarves.random_each (|x| list += '#{x} '}
# list равен:
# 'Bashful Dopey Sleepy Happy Grumpy Doc Sneezy '
# (Ha вашей машине порядок может быть другим.)
8.1.19. Преобразование массива в строку с разделителями