Go 编程实例【非阻塞通道 Non-Blocking】

阅读目录

常规的通过通道发送和接收数据是阻塞的。然而,我们可以 使用带一个 default 子句的 select 来实现非阻塞 的 发送、接收,甚至是非阻塞的多路 select。

// non-blocking-channel-operations.go
package main

import "fmt"

func main() {
    
    
	messages := make(chan string)
	signals := make(chan bool)

	// 这里是一个非阻塞接收的例子。如果在 `messages` 中
	// 存在,然后 `select` 将这个值带入 `<-messages` `case`
	// 中。如果不是,就直接到 `default` 分支中。
	select {
    
    
	case msg := <-messages:
		fmt.Println("received message", msg)
	default:
		fmt.Println("no message received")
	}

	// 一个非阻塞发送的实现方法和上面一样。
	msg := "hi"
	select {
    
    
	case messages <- msg:
		fmt.Println("sent message", msg)
	default:
		fmt.Println("no message sent")
	}

	// 我们可以在 `default` 前使用多个 `case` 子句来实现
	// 一个多路的非阻塞的选择器。这里我们试图在 `messages`
	// 和 `signals` 上同时使用非阻塞的接收操作。
	select {
    
    
	case msg := <-messages:
		fmt.Println("received message", msg)
	case sig := <-signals:
		fmt.Println("received signal", sig)
	default:
		fmt.Println("no activity")
	}
}

[root@bogon test]# go run non-blocking-channel-operations.go
no message received
no message sent
no activity
[root@bogon test]# 

猜你喜欢

转载自blog.csdn.net/weiguang102/article/details/129746090
今日推荐