mirror of
https://github.com/golang/go
synced 2024-11-17 17:44:46 -07:00
afb5fca25a
runtime.GC() doesn't guarantee the finalizer has run, so use a channel instead to make sure finalizer was run in call to "after()". Fixes #41361 Change-Id: I69c801e29aea49757ea72c52e8db13239de19ddc Reviewed-on: https://go-review.googlesource.com/c/go/+/254401 Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Matthew Dempsky <mdempsky@google.com> Trust: Cuong Manh Le <cuong.manhle.vn@gmail.com>
47 lines
738 B
Go
47 lines
738 B
Go
// run
|
|
|
|
// Copyright 2020 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// This test makes sure unsafe-uintptr arguments are not
|
|
// kept alive longer than expected.
|
|
|
|
package main
|
|
|
|
import (
|
|
"runtime"
|
|
"unsafe"
|
|
)
|
|
|
|
var done = make(chan bool)
|
|
|
|
func setup() unsafe.Pointer {
|
|
s := "ok"
|
|
runtime.SetFinalizer(&s, func(p *string) { close(done) })
|
|
return unsafe.Pointer(&s)
|
|
}
|
|
|
|
//go:noinline
|
|
//go:uintptrescapes
|
|
func before(p uintptr) int {
|
|
runtime.GC()
|
|
select {
|
|
case <-done:
|
|
panic("GC early")
|
|
default:
|
|
}
|
|
return 0
|
|
}
|
|
|
|
func after() int {
|
|
runtime.GC()
|
|
runtime.GC()
|
|
<-done
|
|
return 0
|
|
}
|
|
|
|
func main() {
|
|
_ = before(uintptr(setup())) + after()
|
|
}
|