go lang學習筆記――channel機理及調(diào)度理解
來源:程序員人生 發(fā)布時間:2015-06-18 08:50:30 閱讀次數(shù):2643次
《Go語言編程》1書介紹了libtask庫,可以認為這個庫同等于go的底層goroutine實現(xiàn)。
libtask庫的channel的數(shù)據(jù)結構以下:
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的基本組成以下:
內(nèi)存緩存,用于寄存元素;
發(fā)送隊列;
接受隊列。
書中羅列完channel的結構后沒有深入講授如何在channel這個結構上進行通訊的進程。其實結合書中前面介紹的內(nèi)容task(協(xié)程)的通訊進程已不言而明了。
但是從學習者的角度,固然是把這個問題講授的越明白越好。接下來我試著介紹1下task(協(xié)程)是如何在這個channel的基礎上通訊的。
對1個往channel里寫數(shù)據(jù)的情況:
對1個從channel里讀數(shù)據(jù)的情況:
注意:以上兩個流程都是基于書中對協(xié)程的工作原理和channel數(shù)據(jù)結構的介紹后我個人腦補的,并沒有去翻看libtask的代碼。極可能存在疏漏,只應當把這兩個流程作為理解協(xié)程工作方式的參照。
生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學習有所幫助,可以手機掃描二維碼進行捐贈