Java读取数据流经常会出问题,结合自己项目中遇到的问题,对此进行一些总结。
当用读取的本地的数据流时,可以利用read()方法把数据读入。关键代码如下:
byte[] buffer = new byte[1024];
int len = -1;
outputStream = new ByteArrayOutputStream();
while((len = mInputStream.read(buffer)) != -1){
outputStream.write(buffer, 0, len);
但是对于网络数据流,这样的方式会导致阻塞的发生!!!所以对于网络数据流分如下两种情况:
第一已经数据流的大小,读取数据流。关键代码如下:
while (count == 0) {
for(int i=0;i<10;i++){
Thread.sleep(1000);
count = mInputStream.available();
}
}
inDatas = new byte[count];
int readCount=0;
int countTemp=0;
while(readCount<count){
if((countTemp=mInputStream.read(inDatas,readCount,count-readCount))!=-1)
readCount+=countTemp;
try {
Thread.sleep(2000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
或者解析自定义数据包的大小,来判断数据包是否接收完毕。若出现丢包的话发生阻塞!!!
第二数据流大小未知。
Java 的 Socket 类提供了 shutdownOutput() 和shutdownInput() 另个方法, 用来分别只关闭 Socket 的输出流和输