国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

skynet學習之skynet_monitor

2019-11-11 04:26:16
字體:
來源:轉載
供稿:網友

今天學習skynet_monitor。

skynet_monitor主要用于監測skynet_context在處理消息時是否陷入死循環。

struct skynet_monitor;struct skynet_monitor * skynet_monitor_new();//新建一個監視器void skynet_monitor_delete(struct skynet_monitor *);//刪除一個監視器void skynet_monitor_trigger(struct skynet_monitor *, uint32_t source, uint32_t destination);//通知監視器開始void skynet_monitor_check(struct skynet_monitor *);//檢查監視器是否陷入死循環skynet啟動時會為每個工作線程創建一個對應的監視器:

static voidstart(int thread) {	pthread_t pid[thread+3];	struct monitor *m = skynet_malloc(sizeof(*m));	memset(m, 0, sizeof(*m));	m->count = thread;	m->sleep = 0;	m->m = skynet_malloc(thread * sizeof(struct skynet_monitor *));	int i;	for (i=0;i<thread;i++) {		m->m[i] = skynet_monitor_new();//創建監視器	}        ......然后,sc在處理消息時,會調用skynet_monitor_trigger:

struct message_queue * skynet_context_message_dispatch(struct skynet_monitor *sm, struct message_queue *q, int weight) {	......        ......	for (i=0;i<n;i++) {		......                ......		skynet_monitor_trigger(sm, msg.source , handle);//開始監視		if (ctx->cb == NULL) {			skynet_free(msg.data);		} else {			dispatch_message(ctx, &msg);//處理消息		}		skynet_monitor_trigger(sm, 0,0);//結束監視	}	......	return q;}監視的驅動是由一個單獨的線程來做的:

static void *thread_monitor(void *p) {	struct monitor * m = p;	int i;	int n = m->count;	skynet_initthread(THREAD_MONITOR);	for (;;) {		CHECK_ABORT		for (i=0;i<n;i++) {			skynet_monitor_check(m->m[i]);		}		for (i=0;i<5;i++) {			CHECK_ABORT			sleep(1);		}	}	return NULL;}從這里可以看出,5秒不退出,就認為死循環成立。

當然處理方案也只是打印了一個日志罷了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永年县| 乳山市| 满洲里市| 苍梧县| 察雅县| 泌阳县| 铁力市| 谢通门县| 石楼县| 舞阳县| 梧州市| 德阳市| 镇原县| 福贡县| 集贤县| 利辛县| 池州市| 墨玉县| 习水县| 丰城市| 广宗县| 扶风县| 义乌市| 蒲城县| 秦安县| 托克托县| 武胜县| 正宁县| 安塞县| 江孜县| 云阳县| 梓潼县| 中牟县| 怀化市| 屯门区| 凉城县| 临夏市| 高雄市| 沧州市| 葫芦岛市| 驻马店市|