Go的并发Java示例

我有以下来自GoByExamples的并发渠道示例

Java中是否有等同的东西?我本以为实现同一件事会更加冗长。

// Basic sends and receives on channels are blocking.

// However, we can use `select` with a `default` clause to

// implement _non-blocking_ sends, receives, and even

// non-blocking multi-way `select`s.

package main

import "fmt"

func main() {

messages := make(chan string)

signals := make(chan bool)

// Here's a non-blocking receive. If a value is

// available on `messages` then `select` will take

// the `<-messages` `case` with that value. If not

// it will immediately take the `default` case.

select {

case msg := <-messages:

fmt.Println("received message", msg)

default:

fmt.Println("no message received")

}

// A non-blocking send works similarly.

msg := "hi"

select {

case messages <- msg:

fmt.Println("sent message", msg)

default:

fmt.Println("no message sent")

}

// We can use multiple `case`s above the `default`

// clause to implement a multi-way non-blocking

// select. Here we attempt non-blocking receives

// on both `messages` and `signals`.

select {

case msg := <-messages:

fmt.Println("received message", msg)

case sig := <-signals:

fmt.Println("received signal", sig)

default:

fmt.Println("no activity")

}

}

回答:

Select语句 在Go中在语言语法级别引入并发的原因。并发函数调用可以(和通常完成)在库级别使用辅助函数(例如spawn(

function())和通道)实现,就像在大多数其他语言中使用互斥或​​锁定的数据结构一样。但是select声明不能。

以上是 Go的并发Java示例 的全部内容, 来源链接: utcz.com/qa/402000.html

回到顶部