channel并发编程

不要通过共享内存通信,要通过通信共享内存。

channel是golang并发编程中一种重要的数据结构,用于多个goroutine之间进行通信。

我们通常可以把channel想象成一个传送带,将goroutine想象成传送带周边的人,一个传送带的上游放上物品,通过传送带的传输,下游的人可以将物品取走。

go 复制代码
package main

import (
	"fmt"
	"time"
)

func main() {
	c := make(chan string, 2)
	s := []string{"A", "B", "C", "D"}
	go func() {
		defer close(c)
		for _, v := range s {
			fmt.Printf("send to chan %v\n", v)
			c <- v
			time.Sleep(1 * time.Second)
		}
	}()
	time.Sleep(5 * time.Second)
	for v := range c {
		fmt.Printf("recieved %v\n", v)
	}
}
go 复制代码
package main

import (
	"fmt"
	"time"
)

func main() {
	c := make(chan string, 2)
	s := []string{"A", "B", "C", "D"}
	go func() {
		//defer close(c)
		for _, v := range s {
			fmt.Printf("send to chan %v\n", v)
			c <- v
			time.Sleep(1 * time.Second)
		}
	}()
	time.Sleep(5 * time.Second)
	for v := range c {
		fmt.Printf("recieved %v\n", v)
	}
}
相关推荐
zhouwy11317 小时前
Golang 基础与实战笔记:从语法到微服务的全面指南
开发语言·go
日火2 天前
Go:实现基于mutex的环形缓冲区
go
审判长烧鸡3 天前
GO错误处理【7】层层递进,环环相扣
go·报错处理
审判长烧鸡3 天前
Go结构体与指针【3】自动解引用
go·指针·结构体·自动解引用
审判长烧鸡3 天前
【GO VS PHP】之 指针/引用传递
go·php·指针·引用传递
审判长烧鸡3 天前
GO错误处理【4】报错即链条
go·异常处理·错误处理
审判长烧鸡3 天前
GO时区【1】定义与使用
go·时区
审判长烧鸡4 天前
GO错误处理【5】显式错误处理
go·错误处理·报错链条
jeff聊企业数字化4 天前
私有化即时通讯选型指南:兼顾安全与高效
go·业界资讯·即时通讯
审判长烧鸡4 天前
GO错误处理【6】显式哲学
go·显式哲学