当前位置: 首页 > news >正文

网站建设的理由wordpress到day one

网站建设的理由,wordpress到day one,网站手机端和电脑端,金蝶软件怎么打印凭证Disruptor框架提供了多种等待策略,每种策略都有其适用的场景和特点。以下是这些策略的详细介绍及其适用场景: 1. BlockingWaitStrategy 特点: 使用锁和条件变量进行线程间通信,线程在等待时会进入阻塞状态,释放CPU资…

Disruptor框架提供了多种等待策略,每种策略都有其适用的场景和特点。以下是这些策略的详细介绍及其适用场景:

1. BlockingWaitStrategy

  • 特点
    • 使用锁和条件变量进行线程间通信,线程在等待时会进入阻塞状态,释放CPU资源。
  • 适用场景
    • 适合对延迟要求不高的应用。
    • 系统资源有限,需要最大化CPU利用率,减少不必要的CPU占用。
    • 典型应用:批处理系统、日志处理系统。

2. BusySpinWaitStrategy

  • 特点
    • 不释放CPU资源,线程不断循环等待事件。
  • 适用场景
    • 适合对延迟非常敏感的应用。
    • 系统有充足的CPU资源,并且能够接受高CPU使用率。
    • 典型应用:高频交易系统。

3. LiteBlockingWaitStrategy

  • 特点
    • 类似于BlockingWaitStrategy,但实现更轻量级。
    • 同样使用锁和条件变量。
  • 适用场景
    • 适合需要节省CPU资源但又不希望完全阻塞的应用。
    • 系统资源有限,且对延迟要求适中。
    • 典型应用:一般的企业应用。

4. LiteTimeoutBlockingWaitStrategy

  • 特点
    • 类似于LiteBlockingWaitStrategy,但支持超时等待。
    • 使用锁、条件变量和超时机制。
  • 适用场景
    • 适合需要节省CPU资源且有超时机制需求的应用。
    • 系统资源有限,对延迟要求适中,并希望在等待超时后进行特定处理。
    • 典型应用:网络通信应用,需要在一定时间内收到响应。

5. PhasedBackoffWaitStrategy

  • 特点
    • 结合了多种等待策略,根据不同的条件逐步后退。
    • 支持多阶段等待,包括忙等待、yield和阻塞等待。
  • 适用场景
    • 适合需要灵活应对不同负载条件的应用。
    • 系统资源情况不确定,且需要在不同负载下自动调整等待策略。
    • 典型应用:动态负载的应用系统。

6. SleepingWaitStrategy

  • 特点
    • 线程在等待时短暂休眠,降低CPU占用。
  • 适用场景
    • 适合对延迟要求不高且希望减少CPU占用的应用。
    • 系统资源有限,且不需要高频事件处理。
    • 典型应用:后台任务处理。

7. TimeoutBlockingWaitStrategy

  • 特点
    • 类似于BlockingWaitStrategy,但支持超时等待。
    • 使用锁、条件变量和超时机制。
  • 适用场景
    • 适合需要节省CPU资源且有超时机制需求的应用。
    • 系统资源有限,对延迟要求适中,并希望在等待超时后进行特定处理。
    • 典型应用:超时网络通信、数据处理任务。

8. YieldingWaitStrategy

  • 特点
    • 使用Thread.yield()方法让出CPU资源,允许其他线程运行。
    • 当没有新事件时,线程会进入短暂的休眠状态。
  • 适用场景
    • 适合延迟敏感的应用场景。
    • 系统有足够的CPU资源来处理并发任务,并希望在高吞吐量和低延迟之间取得平衡。
    • 典型应用:实时数据处理系统。

选择策略的综合建议

  • 低延迟,高吞吐量
    • 使用BusySpinWaitStrategyYieldingWaitStrategy
  • 中等延迟,节省资源
    • 使用SleepingWaitStrategyLiteBlockingWaitStrategyPhasedBackoffWaitStrategy
  • 资源有限,低CPU占用
    • 使用BlockingWaitStrategyTimeoutBlockingWaitStrategy

示例代码

使用PhasedBackoffWaitStrategy
Disruptor<Holder> disruptor = new Disruptor<>(new HolderEventFactory(),bufferSize,new ThreadFactoryBuilder().setNameFormat("disruptor-thread-%d").build(),ProducerType.MULTI,PhasedBackoffWaitStrategy.withLock(new BusySpinWaitStrategy(),new BlockingWaitStrategy(),10, TimeUnit.MILLISECONDS)
);

通过理解每种策略的特点和适用场景,可以根据实际需求选择最合适的等待策略,确保系统在高并发情况下既能满足性能要求,又能有效利用系统资源。

http://www.yayakq.cn/news/61265/

相关文章:

  • 做淘宝优惠券网站要多少钱大学生实训网站建设心得
  • 网站制作湖州云南网站建设选天软
  • 安徽省住房和城乡建设厅网站首页网站建设走什么科目
  • 大名专业做网站扩展名 网站
  • 西安网站建设品牌公司推荐济南网站建设哪家便宜
  • 北京网站关键词排名推广视频网站自己怎么做
  • 教育培训推广网站模板设计页面宽度
  • 石家庄最好的网站建设公司哪家好wordpress官网中文
  • 淘宝运营规则东莞网络营销优化
  • 石排镇做网站网站代备案公司
  • 厦门网站设计品牌企业企业网站营销的优缺点
  • 常州建行网站堆龙德庆网站建设
  • 做国际网站江苏建设工程信息网一体化平台官网
  • 企业网站seo怎么做花80亿美元建空间站
  • 简洁大气网站模板wordpress ping百度
  • 虚拟主机网站建设大众拆车件网上商城
  • 沈阳的网站建设论坛网站模
  • 门户网站建设的好处私密浏览器在线观看
  • 网站营销公司简介外包网站多少钱
  • 英文网站收录提交网站设计需要考虑的基本原则
  • 佛山市手机网站建设哪家好推广方式营销方案
  • 长沙做网站公司中国十大网络运营商是哪些
  • 网站推广及seo方案航班网站开发设计说明书
  • 我的WordPress网站网页传奇游戏怎么彻底卸载
  • 七台河哈尔滨网站建设邢台网公众号
  • html网站源代码c2c网站制作
  • 网站icp备案号做网站引流的利润
  • 网站建设费用取得专票会计分录企业软文营销发布平台
  • 竞价网站推广网站制作培训学校
  • 数据可视化网站优化大师有必要花钱吗