Go で構造体の配列要素を削除する
Go で構造体の配列を操作する場合、以下に基づいて要素を削除する必要がある場合があります。特定の条件。ただし、これをループ内で実行しようとすると、「範囲外」エラーが発生する可能性があります。
次の例を考えてみましょう。
type Config struct { Applications []Application } // config is initialized from a JSON file config = new(Config) _ = decoder.Decode(&config) for i, application := range config.Applications { if i == 1 { config.Applications = _removeApplication(i, config.Applications) } } func _removeApplication(i int, list []Application) []Application { if i < len(list)-1 { list = append(list[:i], list[i+1:]...) } else { log.Print(list[i].Name) list = list[:i] } return list }
このコードは、2 番目の要素 (インデックス 1) を削除しようとします。 ) アプリケーションの配列から。ただし、このループで要素を削除すると、特に現在の要素が削除された場合、削除後の要素の位置のシフトにより、誤ったインデックス作成が行われる可能性があります。
推奨される解決策
インデックス作成の問題を回避するには、逆の順序でループすることをお勧めします。
for i := len(config.Applications) - 1; i >= 0; i-- { application := config.Applications[i] // Condition to decide if current element has to be deleted: if haveToDelete { config.Applications = append(config.Applications[:i], config.Applications[i+1:]...) } }
この下向きのループにより、次のことが保証されます。削除された要素の後の要素は適切にシフトされ、範囲外の問題を防ぎます。
以上がGo で構造体の配列から要素を安全に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。