ホームページ バックエンド開発 C++ 反復中に `std::set` から要素を削除するのは C で定義された動作ですか、それとも実装固有ですか?

反復中に `std::set` から要素を削除するのは C で定義された動作ですか、それとも実装固有ですか?

Dec 04, 2024 am 08:30 AM

Is Deleting Elements from a `std::set` During Iteration Defined Behavior in C   or Implementation-Specific?

反復中に std::set から要素を削除する: 実装への影響

要素を削除しながらセットを反復処理すると、操作として課題が発生する可能性があります。イテレータが無効になる可能性があります。この文脈で、次のような疑問が生じます: この動作は C 標準によって定義されていますか、それとも実装固有ですか?

実装の依存関係

C 標準 (23.1) による.2.8)、セットへの要素の挿入はイテレータやコンテナへの参照に影響を与えるべきではありませんが、要素の削除は無効化のみを行う必要があります。イテレータと削除された要素への参照。ただし、消去操作中の反復子の動作は明示的に指定されていないため、実装固有の決定に委ねられています。

GCC 実装

提供されているサンプル コードでは、次のように使用しています。 Ubuntu 10.04 上の GCC 4.3.3 では、反復中にセットから要素を削除しても反復子は無効になりませんでした。これは、GCC の実装がより緩和されたアプローチに従っており、消去後の反復子の継続使用を許可していることを示唆しています。

適合ソリューション

標準への準拠を保証するには、別のアプローチが必要です。が必要です。一般的な解決策の 1 つは、要素を消去する前にイテレータのコピーを作成することです。

for (auto it = numbers.begin(); it != numbers.end(); ) {
    if (*it % 2 == 0) {
        numbers.erase(it++);
    }
    else {
        ++it;
    }
}
ログイン後にコピー

この場合、後置インクリメント (it ) は古い位置を Erase() 関数に渡しながら同時に、次の要素。ここでは、接頭辞の増分 (条件が false の場合) で発生する可能性のある二重増分の問題を回避するため、後置増分が推奨されます。

C 11 Update

With C 11 の登場により、より洗練されたソリューションが利用可能になりました。 Erase() 関数は、削除された最後の要素 (最後の要素が削除された場合は set::end) に続く要素への反復子を返すようになりました。これにより、より簡潔な実装が可能になります:

for (auto it = numbers.begin(); it != numbers.end(); ) {
    if (*it % 2 == 0) {
        it = numbers.erase(it);
    }
    else {
        ++it;
    }
}
ログイン後にコピー

以上が反復中に `std::set` から要素を削除するのは C で定義された動作ですか、それとも実装固有ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? Mar 03, 2025 pm 05:52 PM

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか?

GULC:Cライブラリはゼロから構築されています GULC:Cライブラリはゼロから構築されています Mar 03, 2025 pm 05:46 PM

GULC:Cライブラリはゼロから構築されています

c言語関数形式文字ケース変換手順 c言語関数形式文字ケース変換手順 Mar 03, 2025 pm 05:53 PM

c言語関数形式文字ケース変換手順

C言語関数の定義と呼び出しルールは何ですか、そして C言語関数の定義と呼び出しルールは何ですか、そして Mar 03, 2025 pm 05:53 PM

C言語関数の定義と呼び出しルールは何ですか、そして

メモリに保存されているC言語関数の返品値はどこにありますか? メモリに保存されているC言語関数の返品値はどこにありますか? Mar 03, 2025 pm 05:51 PM

メモリに保存されているC言語関数の返品値はどこにありますか?

明確な使用法とフレーズ共有 明確な使用法とフレーズ共有 Mar 03, 2025 pm 05:51 PM

明確な使用法とフレーズ共有

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? Mar 12, 2025 pm 04:52 PM

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか?

C標準テンプレートライブラリ(STL)はどのように機能しますか? C標準テンプレートライブラリ(STL)はどのように機能しますか? Mar 12, 2025 pm 04:50 PM

C標準テンプレートライブラリ(STL)はどのように機能しますか?

See all articles