>백엔드 개발 >Golang >Go에서 구조체 배열의 요소를 효율적으로 삭제하는 방법은 무엇입니까?

Go에서 구조체 배열의 요소를 효율적으로 삭제하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-07 21:12:13455검색

How to Efficiently Delete Elements from Struct Arrays in Go?

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'에서 삭제된 요소에 액세스하려고 시도합니다. 이 문제를 해결하려면 다음 효율적인 삭제 기술 중 하나를 사용하는 것이 좋습니다.

  1. 중간 요소 제거:
list = append(list[:i], list[i+1:]...)
  1. 마지막 삭제 요소:
list = list[:i]
  1. 슬라이스 트릭을 사용하여 요소 제거:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.