深入浅出的处理器(续)

01
在这里插入图片描述

02
在这里插入图片描述

03
在这里插入图片描述

04
在这里插入图片描述

05
在这里插入图片描述

06
在这里插入图片描述

07
在这里插入图片描述

08
在这里插入图片描述

09
在这里插入图片描述

10
在这里插入图片描述

11
在这里插入图片描述

12
在这里插入图片描述

13
在这里插入图片描述

14
在这里插入图片描述

伪代码:问题发现

伪代码:问题发现

void process(Message* msg)
{
	Parser* p = find_parser(msg->type);
	if (p != NULL)
	{
		p->handle(msg); 
	}
}

分析:
每一条信息过来,就要查找,性能的瓶颈在这里:Parser* p = find_parser(msg->type);
后来发现有一个局部性表现,短时间内有大量的消息打印,消息类型是一样的
程序的局部性原理=》缓存=》利用缓存的机制处理问题

p->handle(msg); // 每个消息都有一个线程,放到线程里,这里没有性能瓶颈

优化:突破性能瓶颈

优化:突破性能瓶颈

void process(Message* msg)
{
	Static Parser* cache = NULL;
	
	// 先判断缓存的解析器是否能够解析消息
	if ( (cache != NULL) && (cache->id == message->type) )
	{
		cache->handle(msg); 
	}
	else
	{
		Parser* p = find_parser(msg->type);
		if (p != NULL)
		{
			p->handle(msg); 
			cache = p;
		}
	}
}

分析:避免了一些查找
后来再次优化,好嘞只有一个缓存,能不能多几个缓存?

优化:二级缓存

优化:二级缓存

void process(Message* msg)
{
	Static Parser* cache1 = NULL;
	Static Parser* cache2 = NULL;
	
	// 先判断缓存的解析器是否能够解析消息
	if ( (cache != NULL) && (cache->id == message->type) )
	{
		cache->handle(msg); 
	}
	else
	{
		Parser* p = find_parser(msg->type);
		if (p != NULL)
		{
			p->handle(msg); 
			cache = p;
		}
	}
}

分析:
解决短时间的大量消息和大量消息属于几种类型?  伪代码待完善
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值