V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
gengzi
V2EX  ›  Java

看 Ribbon 轮询的负载策略源码中,循环获取可用服务,使用了 Thread.yield()有什么用意?

  •  
  •   gengzi · 74 天前 · 830 次点击
    这是一个创建于 74 天前的主题,其中的信息可能已经有所发展或是发生改变。

    while (server == null && count++ < 10) { // 省略。。 if (server == null) { /* Transient. */ Thread.yield(); continue; } // 省略。。 }

    看代码应该是 9 年期,难道只是出让一次机会给别的线程执行?

    4 条回复    2021-09-22 14:00:46 +08:00
    kkkkkrua
        1
    kkkkkrua  
       74 天前
    意思就是 sleep 的优雅版
    carrotrollroll
        2
    carrotrollroll  
       74 天前
    这不是每次循环都出让一次嘛?
    xxxrubyxxx
        3
    xxxrubyxxx  
       73 天前
    让出线程拿到的时间片,让其他线程去竞争,Thread.sleep()会让线程阻塞在哪里,浪费 cpu 资源
    huang119412
        4
    huang119412  
       71 天前
    看注释:A hint to the scheduler that the current thread is willing to yield its current use of a processor. The scheduler is free to ignore this hint.
    实际上这个可以极大增加 CPU 利用率,Disruptor 高性能就是靠 CAS + yield
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3794 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 07:42 · PVG 15:42 · LAX 23:42 · JFK 02:42
    ♥ Do have faith in what you're doing.