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

来源:互联网 发布:当代传播 大数据 高涛 编辑:程序博客网 时间:2024/05/22 05:06


    今天在项目测试过程中,为了达到每隔秒向服务器发送消息的目的,所以做了个循环并每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)后面,竟然每次的写入都可成功。虽然找到的解决方法,但为什么产生问题还不明了,希望哪位大神能来解惑,谢谢!
原创粉丝点击