전혀 할당하지 않아야 하는 코드가 있는데 어떤 이유로 할당됩니다. 벤치마크에 따르면 작업당 2번의 할당이 발생합니다.
어떤 함수 라인이 할당되나요? 왜?
특징:
으아아아벤치마크:
으아아아하고 싶었지만 buf
切片以某种方式逃逸,但我不知道如何逃逸,因为据我了解,在这种情况下切片是在堆栈上分配的结构,它将指向变量 b
作为其数据。我尝试将表达式 unsafe.Slice(&b, 1)
更改为 (*[1]byte)(unsafe.Pointer(&b))[:]
아무것도 바뀌지 않았습니다.
값이 인터페이스에 포함되면 항상 탈출 가능한 것으로 간주됩니다. 값이 호출 스택 외부에서 사용되지 않더라도 Go는 해당 시점에서 구문 분석을 중지하고 누군가가 붙잡았을 수도 있다고 생각합니다. 주소의 경우 값은 힙에 배치되어야 합니다.
Since Read
采用 io.Reader
和 Write
采用 io.Writer
,因此 buf
(这是传递给这两个函数的 bytes.Buffer
)을 이스케이프해야 합니다.
이러한 함수를 구체적인 유형으로 만들더라도 bytes.Buffer
(您可能不想要),但这还不够,因为 Read
调用 io.ReadFull
,它再次采用 io.Reader
. 이 임무를 면제받으려면 그보다 더 열심히 일해야 합니다.
참고로 Read
中的其他问题,有一个更简单的解决方案,不需要任何 unsafe.Slice
恶作剧:只需将 var b byte
替换为 var b [1]byte
(这正是 内存中相同),将b[:]
传递给ReadFull
,并在其他使用b
的地方使用b[0]
를 위해.
위 내용은 무엇이 힙으로 빠져나가나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!