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

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

skynet學習之skynet_monitor

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

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沛县| 安康市| 潼南县| 巴里| 崇信县| 鄂温| 洛川县| 襄汾县| 柘荣县| 西畴县| 汾阳市| 衡东县| 北碚区| 蛟河市| 天台县| 黄石市| 兴国县| 阿图什市| 光泽县| 连州市| 白河县| 尼木县| 南江县| 仁化县| 中牟县| 泰顺县| 宜宾县| 彭泽县| 桓仁| 盐山县| 深圳市| 河北省| 邓州市| 会泽县| 孟连| 青阳县| 赤城县| 麻栗坡县| 大丰市| 会泽县| 秦安县|