netty中使用Thread.sleep()方法的问题


    今天在项目测试过程中,为了达到每隔秒向服务器发送消息的目的,所以做了个循环并每100次等待3秒,代码为如下:

if(channel.isWritable()){
         for(int i = 0; i < testN; i++){
              if(i % 100 == 0){
                  Thread.sleep(1000);
              }future = channel.write(s);
         }
         future.addListener(ChannelFutureListener.CLOSE);}

     这样执行后,却发现在服务端,除了第一次数据能收到,以后的每次都不行,打印isWritable方法发现返回均为false,说明IO已经被阻塞,当前无法写入。甚是苦恼,百度谷歌后也没发现具体解决方法。
   后来偶尔一次,把sleep语句放在channel.write(s)后面,竟然每次的写入都可成功。虽然找到的解决方法,但为什么产生问题还不明了,希望哪位大神能来解惑,谢谢!

你可能感兴趣的:(netty,netty,sleep,阻塞)