ホームページ >バックエンド開発 >Golang >Go でスライスから重複エントリを効率的に削除するにはどうすればよいですか?

Go でスライスから重複エントリを効率的に削除するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-02 01:53:02946ブラウズ

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

スライスからの重複の削除

各ピアがアドレスと PeerID によって特徴付けられているテキスト ファイルから重複ピアを削除することを目的としています。提供されたコードはこのタスクに効果的に取り組みますが、最後の重複を削除するときにエラーが発生します。これを解決するために、改訂されたアプローチが提示されています。

まず、変数 i を宣言し、0 に初期化します。この変数は、cfg.Bootstrap スライス内の重複していない最後のピアのインデックスを追跡します。次に、範囲ベースの for ループを使用してスライスをループします。

ループ内で、現在のピアのアドレスとピア ID が削除するピアのアドレスとピア ID に一致するかどうかを確認します。存在する場合は、現在のピアをスキップします。それ以外の場合は、現在のピアを cfg.Bootstrap[i] に割り当て、i をインクリメントします。

ループが終了すると、cfg.Bootstrap[i:] には削除する必要がある重複ピアのみが含まれます。これらの余分な値をトリミングするには、cfg.Bootstrap[:i] を cfg.Bootstrap に割り当て直します。

修正されたコード スニペットは次のとおりです:

<code class="go">i := 0
for _, v := range cfg.Bootstrap {
   if v.PeerId == peer.PeerId &amp;&amp; v.Address == peer.Address {
      continue
   }
   cfg.Bootstrap[i] = v
   i++
}
cfg.Bootstrap = cfg.Bootstrap[:i]</code>

この修正されたアプローチでは、重複するピアをすべて効率的に削除します。最下位の者も含みます。

以上がGo でスライスから重複エントリを効率的に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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