contents.push(xhr.responseText); // Иначе сохранить содержимое
}
// Отослать массив содержимого URL-адресов обратно основному потоку
postMessage(contents);
}
22.5. Типизированные массивы и буферы
Как говорилось в главе 7, массивы в языке JavaScript являются многоцелевыми объектами с числовыми именами свойств и специальным свойством
length
. Элементами массива могут быть любые JavaScript-значения. Массивы могут увеличиваться и уменьшаться в размерах и быть разреженными. Реализации JavaScript выполняют множество оптимизаций, благодаря
которым типичные операции с массивами в языке JavaScript выполняются очень быстро. Типизированные массивы - это объекты, подобные массивам (раздел 7.11), которые имеют несколько важных отличий от обычных массивов:
• Все элементы типизированного массива являются числами. Конструктор, используемый для создания массива, определяет тип (целые числа со знаком или без знака или вещественные числа) и размер (в битах) чисел.
• Типизированные массивы имеют фиксированную длину.
• Элементы типизированного массива всегда инициализируются значением 0 при его создании.
Всего существует восемь разновидностей типизированных массивов, каждый с различным типом элементов. Создавать их можно с помощью следующих конструкторов:
При создании типизированного массива конструктору передается размер массива. Вместо размера можно передать массив или типизированный массив, который будет использован для инициализации элементов нового массива. После создания типизированного массива его элементы можно читать или изменять с помощью обычной формы записи с квадратными скобками, как и при работе с любым другим объектом, подобным массиву:
var bytes = new Uint8Array(1024); // Один килобайт байтов
for(var і = 0; і < bytes.length; і++) // Для каждого элемента массива
var copy = new Uint8Array(bytes); // Создать копию массива
var ints = new Int32Array([0,1,2,3]); // Типизированный массив с 4 целыми
Современные реализации JavaScript оптимизируют операции с массивами и делают их очень эффективными. Однако типизированные массивы могут быть еще более эффективными, как по времени выполнения операций с ними, так и по использованию памяти. Следующая функция вычисляет наибольшее простое число, которое меньше указанного значения. Она использует алгоритм «Решето Эратосфена», который основан на использовании большого массива, в котором запоминается, какие числа являются простыми, а какие составными. Так как в каждом элементе массива требуется сохранять всего один бит информации, объект Int8Array может оказаться более эффективным в использовании, чем обычный массив JavaScript:
// Возвращает наибольшее целое простое число меньше п.
// Использует алгоритм "Решето Эратосфена"
function sieve(n) {
var а = new Int8Array(n+1); // в a[x] записывается 1, если х - составное число
var max = Math.floor(Math.sqrt(n));// Множитель не может быть выше этого значения