国产探花免费观看_亚洲丰满少妇自慰呻吟_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秒不退出,就認為死循環成立。

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 环江| 城固县| 申扎县| 施秉县| 兴山县| 宜兰市| 泸定县| 唐山市| 柘城县| 武穴市| 勃利县| 恭城| 镇江市| 上思县| 尚志市| 文山县| 新宾| 玉田县| 新丰县| 紫金县| 封丘县| 阳东县| 永康市| 六盘水市| 丽江市| 徐汇区| 禄丰县| 辉南县| 崇左市| 华宁县| 西盟| 滦平县| 萨迦县| 渑池县| 盱眙县| 陇西县| 海宁市| 刚察县| 绥化市| 浦东新区| 伊川县|