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