After(d) actually returns timer.c. When the time of D arrives, the current time can be obtained through chan.

func After(d Duration) <-chan Time {
	return NewTimer(d).C
}
Copy the code

Time.after lets you do some processing After a certain time

package main import ( "context" "fmt" "time" ) func worker(ctx context.Context) { for { select { case <-ctx.Done(): Fmt. Println(" Coroutines will stop..." Return default: FMT.Println(" Coroutine working...") ) time.Sleep(time.Second) } } } func main() { ctx,cancel := context.WithCancel(context.Background()) go worker(ctx) Select {case < -time.after (3* time.second): cancel()} time.sleep (time.second) fmt.println ("main exit ")}Copy the code