ジェネレーター関数は、通常の関数とは異なり、関数内の実行を一時停止し、値を逐次的に生成することができます。これにより、巨大なデータセットや非同期処理などの場面で効果的に使用することができます。
以下に、ジェネレーター関数の基本的な構文を示します。
function* myGenerator() {
// ジェネレーター関数の本体
yield value;
// yield文によって値を生成
// 必要な数だけyield文を使用できる
// ...
}
ジェネレーター関数を呼び出すと、ジェネレーターオブジェクトが返されます。このオブジェクトは、next()
メソッドを介して値を生成し、関数の実行を再開することができます。以下に例を示します。
function* numberGenerator() {
yield 1;
yield 2;
yield 3;
}
const generator = numberGenerator();
console.log(generator.next()); // { value: 1, done: false }
console.log(generator.next()); // { value: 2, done: false }
console.log(generator.next()); // { value: 3, done: false }
console.log(generator.next()); // { value: undefined, done: true }
ジェネレーター関数では、yield
文を使用して値を返します。yield
文は、関数の実行を一時停止し、生成された値とともにオブジェクトを返します。done
プロパティは、ジェネレーター関数の実行が完了したかどうかを示します。
ジェネレーター関数は、複数の値を生成するだけでなく、引数を受け取ることもできます。また、ループ処理や非同期タスクの管理にも利用できます。以下に例を示します。
function* fibonacciGenerator(limit) {
let previous = 0;
let current = 1;
while (current <= limit) {
yield current;
const next = previous + current;
previous = current;
current = next;
}
}
const fibonacci = fibonacciGenerator(100);
for (const number of fibonacci) {
console.log(number);
}
この例では、フィボナッチ数列を生成するジェネレーター関数を定義しています。引数として与えられた上限までのフィボナッチ数列を生成し、for...of
ループを使用して値を取得しています。
ジェネレーター関数は、非同期処理においても有用です。非同期ジェネレーター関数を使用することで、非同期タスクをシンプルかつ直感的に管理することができます。
以上が、JavaScriptにおけるジェネレーター関数の基本的な使い方とコード例です。ジェネレーター関数を活用することで、効率的で柔軟なコードを作成し、反復処理や非同期処理をより簡潔に表現することができます。ぜひ、ジェネレーター関数を活用して、より効率的なプログラミングを実現してください。