Golang의 구조체 배열에서 요소를 효율적으로 삭제
구조체 배열로 작업하는 동안 조건에 따라 특정 요소를 제거해야 하는 경우가 종종 있습니다. . 다음 코드는 'config.Applications'라는 배열에서 인덱스 'i'에 있는 요소를 삭제하려고 할 때 발생하는 문제를 보여줍니다.
type Config struct { Applications []Application } 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 }
이 코드는 "범위를 벗어났습니다" 오류를 발생시킵니다. for 루프는 여전히 인덱스 'i'에서 삭제된 요소에 액세스하려고 시도합니다. 이 문제를 해결하려면 다음 효율적인 삭제 기술 중 하나를 사용하는 것이 좋습니다.
list = append(list[:i], list[i+1:]...)
list = list[:i]
list = list[:i+copy(list[i:], list[i+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 중국어 웹사이트의 기타 관련 기사를 참조하세요!