[@talishboy][¥20]什么是 Busy spin?我们为什么要使用它?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

[@talishboy][¥20]什么是 Busy spin?我们为什么要使用它?

李博 bluemind 2018-12-13 13:26:01 1061

问题来自Java技术沙龙的李博
Java线下沙龙报名链接:https://yq.aliyun.com/activity/796

Java
分享到
取消 提交回答
全部回答(1)
  • cysnow
    2019-07-17 23:20:29

    Busy spin是一种在不释放CPU的基础上等待事件的技术。它经常用于避免丢失CPU的缓存中的数据(如果线程先暂停,之后再其他CPU上运行就会丢失)。所以,如果你的工作要求低延迟,并且你的线程目前没有任何顺序,这样你就可以通过循环检测队列中的新消息来代替调用 sleep() 或 wait() 方法。它唯一的好处就是你只需等待很短的时间,如几微秒或几纳秒。LMAX 分布式框架是一个高性能线程间通信的库,该库有一个BusySpinWaitStrategy 类就是基于这个概念实现的,使用 busy spin 循环EventProcessors 等待屏障。

    0 0
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

推荐文章
相似问题
推荐课程