C では、ベクトルを反復するには、反復子を使用するか、インデックスを使用する 2 つの一般的なアプローチがあります。インデックスを使用するときは、インデックス変数の型を考慮することが重要です。
イテレータは、コンテナを反復処理する便利な方法です。これらは、さまざまなタイプのコンテナに統一されたインターフェイスを提供し、要素の効率的な走査を可能にします。次のコードは、反復子を使用してベクトルを反復処理する方法を示しています。
for (auto it = v.begin(); it != v.end(); ++it) { // do something with *it }
インデックスを使用してベクトルを反復処理する場合、符号付きインデックス変数を使用することが重要です。これは、ベクトルには 0 から size() - 1 までのインデックスが付けられており、符号付き変数はこの範囲をより自然に表現できるためです。次の例では、符号付き int を使用してベクトルのインデックスを作成しています。
for (int i = 0; i < v.size(); i++) { // do something with v[i] }
符号なしインデックス変数の使用は、危険な可能性があります。インデックスがベクトルのサイズを超えると、未定義の動作が発生します。これは、符号なし変数は最大値に達するとラップアラウンドするため、インデックスが負になる可能性があり、ベクトルの有効なインデックスではありません。
次の例では、unsigned int は次のようになります。ベクトルのインデックスに使用され、ベクトルのサイズが unsigned int の最大値より大きい場合、インデックスはラップアラウンドして負になり、未定義の動作が発生します:
for (unsigned int i = 0; i < v.size(); i++) { // do something with v[i] }
ベクトルを反復処理する場合は、常に符号付きインデックス変数を使用することをお勧めします。これは、インデックスが常にベクトルの有効範囲内にあることが保証され、未定義の動作の可能性が回避されるためです。
以上がインデックスを使用して std::vector を反復処理するときに、符号付き整数を使用する必要があるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。