java reactor设计模式_reactor设计模式处理网络高并发IO请求

同步编程

while(1)

{

epoll_wait(...)

for(;;)

{

if (fd == listenner_socket)

{

cfd = accpt(listenner_socket);

}

else

{

read(fd, buf, size);

process(buf);

}

}

}

缺点:所有的处理都放在同一个线程里,这个线程的压力很大,因为网络IO的处理总是比CPU要慢很多;

同时如果这里有一个客户端的请求,处理比较复杂,则会影响后面其它客户端的请求的响应时间;

半异步半同步编程

T1线程:

while(1)

{

epoll_wait(...)

for(;;)

{

if (fd == listenner_socket)

{

cfd = accpt(listenner_socket);

}

else

{

read(fd, buf, size);

enqueue(buf);

}

}

}

T2线程:

while (1)

{

wait_queue(buf);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值