Home > Backend Development > Golang > Why Does Go\'s Map Output Seem Ordered Despite Maps Being Unordered?

Why Does Go\'s Map Output Seem Ordered Despite Maps Being Unordered?

Mary-Kate Olsen
Release: 2024-12-01 13:43:11
Original
165 people have browsed it

Why Does Go's Map Output Seem Ordered Despite Maps Being Unordered?

Assignment Order in Maps

In Go, maps are unordered collections of key-value pairs. However, the output of the following code snippet appears to suggest an order to the key-value pairs:

package main

import "fmt"

type Vertex struct {
    Lat, Long float64
}

var m map[string]Vertex

func main() {
    m = make(map[string]Vertex)
    m["Bell Labs"] = Vertex{
        40.68433, 74.39967,
    }
    m["test"] = Vertex{
        12.0, 100,
    }
    fmt.Println(m["Bell Labs"])
    fmt.Println(m)
}
Copy after login

When the above code snippet is executed, it outputs:

{40.68433 74.39967}
map[Bell Labs:{40.68433 74.39967} test:{12 100}]
Copy after login

However, if the whitespace around the right curly brace in the assignment of the "test" key is modified, the output changes:

m["test"] = Vertex{
    12.0, 100,
}
Copy after login

With this modification, the output becomes:

{40.68433 74.39967}
map[test:{12 100} Bell Labs:{40.68433 74.39967}]
Copy after login

Explanation

The observed behavior is due to the randomization of Go's map hash function. This randomization is implemented to prevent denial of service attacks that exploit hash collisions. As stated in the Go issue tracker:

http://code.google.com/p/go/issues/detail?id=2630
Copy after login

Map order is not guaranteed in Go. Although current implementations do not explicitly reorder maps, future implementations may compact maps during GC or other operations, potentially affecting the order. Therefore, it is unwise to rely on map order in your code.

The above is the detailed content of Why Does Go\'s Map Output Seem Ordered Despite Maps Being Unordered?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template