如果我从另一个线程调用inputStream上的close(),则流将关闭,但阻塞的read()调用仍然被阻止.我假设read()方法现在应该以值-1返回以指示流的结束,但它不会.相反,它会被阻塞几分钟,直到发生tcp超时.
如何取消阻止close()调用?
编辑:
显然,当阻塞的read()调用对应的流或套接字是close()’时,常规JRE会立即抛出SocketException.但是,我使用的Android Java运行时不会.
任何有关AndroID环境解决方案的提示都将不胜感激.
解决方法@H_301_14@ 只有有可用数据时才调用read().做那样的事情:
while( flagBlock ) { if( stream.available() > 0 ) { stream.read( byteArray ); } }
设置flagBlock以停止读取.
总结以上是内存溢出为你收集整理的如何在Android上解锁InputStream.read()?全部内容,希望文章能够帮你解决如何在Android上解锁InputStream.read()?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)