Answer 1:

package main

import (
    "fmt"
    "sync/atomic"
    "time"
)

func main()  {

    var count uint32

    trigger := func(i uint32, fn func()){
        for{
            if n := atomic.LoadUint32(&count); n == i {
                fn()
                atomic.AddUint32(&count, 1)
//                count++
                break
            }
            time.Sleep(time.Nanosecond)
        }
    }

    for i := uint32(0); i <100; i++ {
        go func(index uint32) {
            fn := func() {
                fmt.Println(index)
            }
            trigger(index, fn)
        }(i)
    }
    trigger(100, func() {})
}
Copy the code

2 explain why atomic operation count is used.

If atomic guarantee atomicity is not applied, count++ will be issued, and the CPU will be scheduled offline halfway through execution, where the value of count may be uncertain, such as 200, causing lines waiting for 200 to print first. Not as expected.