gopointersmemory-managementgarbage-collectionruntime-error

Why does Go not throw an error when dereferencing a dangling pointer immediately after a variable goes out of scope?


I’m learning about Go’s memory management and garbage collection, and I’ve encountered some unexpected behavior when trying to dereference a pointer after the variable it points to goes out of scope.

In Go, I understand that garbage collection (GC) is automatic and that pointers can sometimes reference memory that is no longer valid. I expected that dereferencing a pointer to an out-of-scope variable would throw an error, but it seems like Go doesn't throw an error when doing so

Here’s a minimal example that demonstrates the issue:

package main

import (
    "fmt"
    "runtime"
)

func main() {
    var p *int
    {
        x := 42
        p = &x  // p points to x
        fmt.Println(*p) // Prints 42
    }

    // Force garbage collection (for testing)
    runtime.GC()

    // Dereferencing p here should cause an error (since x is out of scope)
    fmt.Println(*p) // This does NOT throw any error
}

What I expected:

What actually happens:


Solution

  • The GC does not care about the scope. It checks if there are active pointers to a memory object. In your case, there is at least one.

    The variable x may be out of scope, but p is not, and it is pointing to x, and there is a goroutine using p, so x will not be garbage collected. It will be ready for collection after the function returns, because p will be out of scope as well.