🔥 NEW! Get my book The Developer's Guide to Having a Successful Blog
In this book I teach you all I know about starting and growing a blog.
Launch promo: 25% OFF until tomorrow! And a special challenge for you!
Pointers are not unique to Go, but Go has a unique flavour of pointers, so it’s good to learn why they are unique, as you’ll use pointers in every Go program.
Everything in Go is passed by value, as in C and in all languages descending from C.
If you pass an Int to a function, the variable is copied.
If you pass a pointer, the pointer is copied, but not the value it points to.
So, in most cases pointers are used to call functions and pass parameters by reference.
Let’s take a simple variable
x, defined as an integer with value
x := 5
Now, the memory address of
x can be obtained with
If you print
fmt.Println, you’ll see that it’s something like
0xc42000e248: a memory address.
Now, we can assign this value to a variable, and that variable will be a pointer to
y := &x
If we write this assignment statement
*y = 10
x value will now be
No pointer arithmetic
Go pointers are similar to C and C++ pointers, but they are safer, as you cannot perform operations like
var x *int; x++;
on a pointer, because the address of a pointer cannot be altered. No pointer/array duality.
Returning pointers of local function variables
Local function variables referenced by returned pointers will remain available while the pointer is available. This will make sure the pointer is always pointing to what you think.
The zero value of a pointer is
nil. This means that a nil pointer is still possible, but this causes fewer issues than in other languages (C, Java, C++) because there are less types masked as pointers, and less other nils laying around. For example, strings in C are pointers. In Go, they are a type.
nil is not a common return for functions, like in single return value languages — error checking is more organized, and
nil is not a common zero value. Many built-in data types (strings, arrays, maps, slices..) have zero values different than