For 루프 없이 Go에서 배열 초기화
Go에서 배열로 작업할 때 해당 값을 초기화해야 하는 경우가 많습니다. 가장 간단한 방법은 다음 예에서 볼 수 있듯이 for 루프를 사용하는 것입니다.
<code class="go">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>
복합 리터럴은 항상 주어진 유형에 대해 배열을 0 값으로 초기화합니다. bool의 경우 모든 값이 false가 된다는 뜻입니다.
상수 사용
모든 요소를 특정 값(예: true)으로 초기화하려는 경우 ), 상수를 도입하고 복합 리터럴에서 사용할 수 있습니다:
<code class="go">const T = true b3 := []bool{T, T, T}</code>
대체 논리
특정 상황에서는 상수를 저장하는 것이 더 효율적일 수 있습니다. 배열에서 원하는 값의 역수입니다. 이를 통해 기본 0인 배열 동작을 활용할 수 있습니다.
<code class="go">presents := []bool{true, true, true, true, true, true} // Equivalent to: missings := make([]bool, 6) // All false (not missing)</code>
효율적인 "memset" 작업
성능이 중요한 경우 다음 사용을 고려할 수 있습니다. memset 작업 구현:
<code class="go">import ( "bytes" "unsafe" ) func memset(p []interface{}, v interface{}) { b := bytes.NewBuffer(make([]byte, unsafe.Sizeof(v))) b.Reset() for i := range p { b.Write(b.Bytes()) copy(p[i:i+1], *(*[]byte)(unsafe.Pointer(&v))) } }</code>
이 접근 방식은 대규모 배열에 특히 효율적입니다.
위 내용은 for 루프를 사용하지 않고 Go에서 배열을 어떻게 초기화할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!