NIO 的疑惑,多线程下调用 register 阻塞,是什么原因呢? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
atfeel

NIO 的疑惑,多线程下调用 register 阻塞,是什么原因呢?

  •  
  •   atfeel 2022 年 8 月 28 日 12508 次点击
    这是一个创建于 1335 天前的主题,其中的信息可能已经有所发展或是发生改变。

    1 、在主线程统一轮询处理 select() 2 、子线程调用 register 注册通道。

    register 会阻塞,无法往下执行。什么原因造成的呢?又该如何避免呢?各位有没有碰到过呢

    5 条回复    2022-08-29 10:45:16 +08:00
    dreamlike
        1
    dreamlike  
       2022 年 8 月 28 日 via Android
    有这个问题说明你应该是 j8 左右的版本,这个是内部实现问题 select 会持有和 register 相同的一把锁 具体请看
    https://bugs.openjdk.org/browse/JDK-6446653
    11 改了一次实现 就不会了
    但是还是推荐 register 和 select 在同一个线程中执行,比如说先投递到 select 对应的线程队列中一个 register 任务 再调用 wakeup 让它从 select 中返回
    atfeel
        2
    atfeel  
    OP
       2022 年 8 月 28 日
    @dreamlike 大佬,你说 j8 是 java8 吗?还是 jdk8 呢?
    atfeel
        3
    atfeel  
    OP
       2022 年 8 月 28 日
    @dreamlike 我也想把轮询和注册写在同一线程,但是注册完以后轮询是写在 while 里的,如果不写在新的线程里,那就是整个线程都堵塞在 select ,就没办法做其他操作了。
    dreamlike
        4
    dreamlike  
       2022 年 8 月 28 日 via Android   1
    atfeel
        5
    atfeel  
    OP
       2022 年 8 月 29 日
    @dreamlike 太牛了,昨天我也式了唤醒再注册这种方式,测试结果是,网络请求比直接同步请求多了 20ms,想不到这个 class 这么全面,大佬果然牛!!!仰望感谢
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2798 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 34ms UTC 11:47 PVG 19:47 LAX 04:47 JFK 07:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86