>  기사  >  백엔드 개발  >  루프 없이 효율적으로 Go에서 배열을 초기화할 수 있는 방법은 무엇입니까?

루프 없이 효율적으로 Go에서 배열을 초기화할 수 있는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-30 23:53:29557검색

How Can You Initialize an Array in Go Efficiently Without Loops?

Go에서 루프 없이 효율적인 배열 초기화

균일한 값으로 배열을 초기화하는 것은 일반적인 for 루프를 사용하여 수행할 수 있습니다. 그러나 대규모 배열의 경우 이 접근 방식은 비효율적입니다. 이 기사에서는 루프를 사용하지 않고 배열을 초기화하는 대체 방법을 살펴봅니다.

기존 접근 방식

기존 방법은 for 루프를 사용하여 배열 요소를 반복하고 각 요소를 원하는 값으로 설정합니다.

<code class="go">var A [n]bool
for i := 0; i < n; i++ {
    A[i] = true
}</code>

대체 접근 방식

  • 복합 리터럴:
    복합 리터럴은 다음을 허용합니다. 슬라이스나 배열을 생성하고 초기화하지만 기존 접근 방식보다 짧지는 않습니다.
<code class="go">b1 := []bool{true, true, true}
b2 := [3]bool{true, true, true}</code>
  • 참 가치를 위한 상수:
    상수 소개 실제 값을 사용하면 코드 길이가 약간 줄어들 수 있습니다.
<code class="go">const T = true
b3 := []bool{T, T, T}</code>
  • 부정 값 저장:
    애플리케이션 로직에 따라 더 효율적일 수 있습니다. 대신 부정된 값을 저장합니다. 이렇게 하면 모두 거짓인 0 값이 적합한 초기화가 됩니다.
<code class="go">presents := []bool{true, true, true, true, true, true}

// Is equivalent to:

missings := make([]bool, 6) // All false
// missings=false means not missing (i.e., present)</code>
  • Memset 작업:
    특정 값으로 배열을 채우는 것을 참조합니다. "memset" 작업으로 사용됩니다. Go에서는 이를 위한 내장 기능을 제공하지 않지만 다른 소스에서 효율적인 솔루션을 찾을 수 있습니다.

위 내용은 루프 없이 효율적으로 Go에서 배열을 초기화할 수 있는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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