>백엔드 개발 >Golang >Go 함수의 포인터 수정이 때때로 원래 값에 영향을 주지 않는 이유는 무엇입니까?

Go 함수의 포인터 수정이 때때로 원래 값에 영향을 주지 않는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-27 11:30:30882검색

 Why Does Pointer Modification in Go Functions Sometimes Not Affect the Original Value?

Go의 포인터 수정, 차이점 이해

Go에서는 함수에 포인터를 전달할 때 일반적으로 값을 수정하려고 합니다. 해당 포인터로 가리킨다. 일반적으로 이는 다음 코드에 설명된 것처럼 역참조를 통해 달성할 수 있습니다.

<code class="go">type Test struct {
    Value int
}

func main() {
    i := Test{2}
    p := &i
    f(p)
    println(i.Value) // Output: 4
}

func f(p *Test) {
    *p = Test{4}
}</code>

그러나 전달된 포인터가 가리키는 구조체의 값이 수정 후에도 변경되지 않은 경우가 있을 수 있습니다. 함수 내에서. 이 문제가 발생하는 이유를 이해하기 위해 수정된 코드 조각을 살펴보겠습니다.

<code class="go">type Test struct {
    Value int
}

func main() {
    i := Test{2}
    p := &i
    f(p)
    println(i.Value) // Output: 2
}

func f(p *Test) {
    // Attempt to modify the pointer value
    p = &Test{4}
}</code>

이 코드 조각은 포인터 값 p를 수정하려고 시도하지만 원래 가리킨 구조체의 값을 변경하는 데 실패합니다. 그 이유는 f() 함수 내에서 p = &Test{4} 할당이 지역 변수 p의 값만 수정하기 때문입니다.

f() 함수 내에서 p는 지역 변수로 처리됩니다. , 여기에 새 값을 할당해도 main() 함수에서 전달된 포인터 값에는 영향을 미치지 않습니다. 결과적으로 p가 가리키는 구조체는 변경되지 않고 인쇄 시 i.Value의 변경되지 않은 값에 반영됩니다.

반대로 다음 코드는 구조체 값을 수정하는 올바른 접근 방식을 보여줍니다.

<code class="go">type Test struct {
    Value int
}

func main() {
    i := Test{2}
    p := &i
    f(p)
    println(i.Value) // Output: 4
}

func f(p *Test) {
    p.Value = 4
}</code>

이 코드에서 p.Value = 4는 p가 가리키는 구조체의 Value 필드를 직접 수정합니다. 이로 인해 구조체 값이 원하는 대로 수정되고, 이는 인쇄 시 i.Value의 업데이트된 값에 반영됩니다.

포인터 자체에 새 값을 할당하는 것은 주목할 가치가 있습니다(p = &Test{에서와 같이). 4}) 다른 효과가 있습니다. 이 할당은 새 구조체를 가리키는 새 포인터를 생성하지만 main() 함수에서 전달된 원래 포인터가 가리키는 구조체의 값에는 영향을 미치지 않습니다.

위 내용은 Go 함수의 포인터 수정이 때때로 원래 값에 영향을 주지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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