WebAssembly.Memory.prototype.grow()

grow()Memory オブジェクトのプロトタイプメソッドで、指定した WebAssembly ページの数だけメモリーインスタンスの大きさを拡張します。

構文

grow(number)

引数

number

メモリーを拡大する WebAssembly ページ数 (それぞれは 64KiB の大きさ)。

返値

以前のメモリーの大きさを、 WebAssembly ページ単位で返します。

grow の使用

以下の例では、新しい WebAssembly メモリーインスタンスを初期サイズ 1 ページ (64KiB)、最大サイズ 10 ページ (640KiB) で作成します。

var memory = new WebAssembly.Memory({initial:1, maximum:10});

それから、インスタンスを 1 ページ分拡張することができます。

const bytesPerPage = 64 * 1024;
console.log(memory.buffer.byteLength / bytesPerPage);  // "1"
console.log(memory.grow(1));                           // "1"
console.log(memory.buffer.byteLength / bytesPerPage);  // "2"

なお、ここでの grow() の返値は直前の WebAssembly ページ数です。

仕様書

Specification
WebAssembly JavaScript Interface: Exception Handling
# dom-memory-grow

ブラウザーの互換性

BCD tables only load in the browser

関連情報