「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Go でスライスから重複アイテムを効率的に削除するにはどうすればよいですか?

Go でスライスから重複アイテムを効率的に削除するにはどうすればよいですか?

2024 年 12 月 22 日に公開
ブラウズ:185

How to Efficiently Remove Duplicate Items from a Slice in Go?

スライスからの重複アイテムの削除

あなたの状況では、スライスから重複アイテムを削除するときに問題が発生しています。スライスを繰り返し処理し、繰り返し中に要素を削除します。これにより、重複する項目がスライスの最後にある場合、インデックス エラーやパニックが発生する可能性があります。

この問題に対処するには、より効率的な方法は、一意の要素をスライスの先頭にコピーしてからトリミングすることです。後は余分な要素。その方法は次のとおりです:

i := 0
for _, v := range cfg.Bootstrap {
    if v.PeerID == peer.PeerID && v.Address == peer.Address {
        continue
    }
    cfg.Bootstrap[i] = v
    i  
}
cfg.Bootstrap = cfg.Bootstrap[:i]

このコードでは:

  • 変数 i を 0 に初期化します。これは、新しいトリムされたスライスのインデックス位置を表します。
  • cfg.Bootstrap の各要素を繰り返し処理します。
  • 要素が両方に一致する場合、ユーザーが指定した PeerID とアドレスの場合はスキップします。
  • それ以外の場合は、要素を新しいスライスの i 番目の位置にコピーします。
  • i を次の位置にインクリメントします。
  • ループの後、新しいスライスを cfg.Bootstrap に割り当て、正しい長さに切り詰めます。

このアプローチすべての重複要素が削除され、プロセス全体でスライスの一貫性が維持されることが保証されます。これにより、反復中に要素を削除するときに発生する可能性のあるインデックス エラーやパニックが回避されます。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3