>  기사  >  백엔드 개발  >  변수를 재할당할 때 동적 유형이 지워지지 않습니다. 이것이 버그인가요?

변수를 재할당할 때 동적 유형이 지워지지 않습니다. 이것이 버그인가요?

PHPz
PHPz앞으로
2024-02-13 16:00:11444검색

重新分配变量时动态类型未清除 - 这是一个错误吗?

PHP 편집기는 "변수를 다시 할당할 때 동적 유형이 지워지지 않습니다. 이것이 버그입니까?"라는 일반적인 질문에 답하기 위해 왔습니다. PHP에서 동적 유형의 변수는 유연성의 중요한 기능 중 하나입니다. 변수에 다른 유형의 값을 다시 할당하면 PHP는 새 값에 따라 변수 유형을 자동으로 조정합니다. 그러나 때로는 변수를 지우는 것을 잊어버리고 예상치 못한 결과를 얻을 수도 있습니다. 그렇다면 이 상황은 실수로 간주됩니까? 함께 살펴보겠습니다.

질문 내용

Go에는 nil 값을 보유한 인터페이스가 nil과 같지 않다는 잘 알려진 특이한 점이 있습니다. 이는 내부적으로 인터페이스가 동적 유형과 값의 조합이기 때문입니다. 둘 다 nil인 경우에만 nil이 됩니다. 그래서 (*MyStruct)(nil) != nil(nil)(nil) == nil. 이 블로그에서는 더 잘 설명합니다.

저를 놀라게 한 이 동작과 관련된 내용을 여기에서 발견했습니다: https://goplay.tools/snippet/VF8oWt9XvO8. 코드도 아래에 복사되어 있습니다.

동적 유형이 할당된 변수를 다시 할당하면 해당 동적 유형이 기억되어 새로운 값으로 유지되는 것 같습니다. 이것은 나에게 예상치 못한 일인 것 같습니다. 변수를 다시 할당하면 과거의 모든 상태를 덮어써야 한다고 생각했습니다.

언어 사양을 확인했는데 좀 애매하네요: https://go.dev/ref/spec#Assignability

으아악

값만 의미하는지, 아니면 값에 동적 입력을 더한 것인지는 확실하지 않습니다.

이 동작은 언어에서 의도적인 것입니까, 아니면 런타임이 모든 상태를 지우지 않고 변수 재할당을 위해 메모리를 재사용하는 것의 일부 부작용입니까?

코드:

<code>
Unlike regular variable declarations, a short variable declaration may redeclare variables provided they were originally declared earlier in the same block ... Redeclaration does not introduce a new variable; it just assigns a new value to the original.
</code>

Solution

귀하의 "예상치 못한" 부분은 다음과 같습니다:

으아악

결과가 nilerr 是接口类型(error)的变量,FuncThatReturnsCustomError() 的返回类型为 *CustomError。这不是一个接口类型,而是一个具体类型(指向 CustomError 的指针)。由于它返回一个非接口值,因此当分配给接口类型的变量时,必须将其包装到接口值中。这是将创建非 nil인터페이스 값이 될 것으로 예상하는 위치입니다. 이는 이전 유형 정보를 "기억"하거나 "보존"하는 것과는 아무 관련이 없습니다.

다음과 같은 인터페이스 결과 유형이 있는 함수를 사용하는 경우:

으아악

테스트해 보세요:

으아악

제공되는 혜택(Go Playground에서 사용해 보세요):

으아악

변수는 그대로 사용할 수 있으니까요. returnNilErr()已经有接口结果类型(error),所以它的返回值不需要打包成接口值,在赋值给err p>관련/중복 가능성 보기:

여기서 Go가 실패하는 이유를 이해하려면 nil 값을 숨기세요

Go FAQ: nil 오류 값이 nil이 아닌 이유는 무엇입니까? 一个>

위 내용은 변수를 재할당할 때 동적 유형이 지워지지 않습니다. 이것이 버그인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제