runtime包:
Gosched(): 主动出让当前go程cpu使用权 一次。(进入就绪态) 提高其他go程获取cpu 的概率。
GOMAXPROCS: 设置当前参与计算的逻辑cpu个数。 返回上次成功设置的个数。如果第一次设置,返回计算机默认逻辑cpu数。
Numcpu() : 返回计算机默认逻辑cpu数。
GC(): 手动调用垃圾回收器。 回收垃圾内存。
Goexit(): 结束当前 go程。并且执行成功注册的 defer 指令。
不能在 主 go程 中使用 Goexit() 结束主go程。 —— 异常:fatal error: no goroutines (main called runtime.Goexit) - deadlock!
比对:
return:返回当前 函数 调用。 return 0(正常) / 非0(1、-1异常)
Goexit():结束当前 go程。
os.Exit(int): 结束 当前 进程。不会指定 defer 注册成功的执行。
channel:管道 —— goroutine 同步
定义语法: ch := make(chan关键字 内部传递的数据类型)
例子: ch := make(chan int) / make(chan string) / make(chan bool)
var chr chan int —— 无效的channel
读channel:
<- ch : 自动舍弃读到的数据
num := <-ch 自动将读到的数据保存至num
写channel:
ch <- channel支持的变量类型
例子: ch <- 10 / ch <- "hello" / ch <- true
管道特性:
1. 管道内的数据只能单向流动。
2. 管道中的数据之能读一次,一旦被读走,不能重复读取。
3. 数据在管道中正确流动,要求读、写两端必须同时在线。
系统文件:
stdin 标准输入:stdin文件:stdin缓冲区:硬件-键盘 —— 0
stdout 标准输出:stdout文件:stdout缓冲区:硬件-屏幕: —— 1
stderr 标准错误:stderr 文件:stderr缓冲区: 硬件-屏幕:—— 2
由操作系统自动打开。自动关闭。
channel 种类:
无缓冲channel: 没有缓冲区 —— channel 不能缓冲任何数据。 有 r 没有写 , r端go程阻塞。 有w,没有 r, w端go程阻塞。 要求 r、w同时在线。
chr := make(chan int)
chr := make(chan int, 0)
有缓冲channel: 自带缓冲区 —— channel 可以根据缓冲区大小,存储适量的数据。
chr := make(chan int, 3)
len(chr): 统计缓冲区剩余元素个数。
cap(chr): 统计缓冲区容量。