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

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

skynet學習之skynet_monitor

2019-11-11 02:57:53
字體:
來源:轉載
供稿:網友

今天學習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秒不退出,就認為死循環成立。

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玛多县| 合作市| 淳化县| 灵璧县| 怀来县| 若羌县| 光泽县| 安宁市| 明溪县| 简阳市| 阜南县| 汶上县| 武定县| 广水市| 新野县| 封开县| 博白县| 张家口市| 昔阳县| 威信县| 邵阳县| 民权县| 布拖县| 张家川| 呼玛县| 新宁县| 普定县| 永年县| 蛟河市| 揭阳市| 连山| 湖南省| 隆回县| 江津市| 巩义市| 青浦区| 新津县| 陇西县| 泉州市| 巴塘县| 德阳市|