go lang學習筆記――channel機理及調度理解
來源:程序員人生 發布時間:2015-06-18 08:50:30 閱讀次數:2647次
《Go語言編程》1書介紹了libtask庫,可以認為這個庫同等于go的底層goroutine實現。
libtask庫的channel的數據結構以下:
struct Alt
{
Channel *c;
void *v;
unsigned int op;
Task *task;
Alt *xalt;
};
struct Altarray
{
Alt **a;
unsigned int n;
unsigned int m;
};
struct Channel
{
unsigned int bufsize;
unsigned int elemsize;
unsigned char *buf;
unsigned int nbuf;
unsigned int off;
Altarray asend;
Altarray arecv;
char *name;
};
我們可以看到channel的基本組成以下:
內存緩存,用于寄存元素;
發送隊列;
接受隊列。
書中羅列完channel的結構后沒有深入講授如何在channel這個結構上進行通訊的進程。其實結合書中前面介紹的內容task(協程)的通訊進程已不言而明了。
但是從學習者的角度,固然是把這個問題講授的越明白越好。接下來我試著介紹1下task(協程)是如何在這個channel的基礎上通訊的。
對1個往channel里寫數據的情況:
對1個從channel里讀數據的情況:
注意:以上兩個流程都是基于書中對協程的工作原理和channel數據結構的介紹后我個人腦補的,并沒有去翻看libtask的代碼。極可能存在疏漏,只應當把這兩個流程作為理解協程工作方式的參照。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈