在server端使用out.write(buffer, 0, byteRead);
在client端获取后使用out.write(buffer);写出来的文件会比源文件大,而且大小不太固定.
如果我在client也换成out.write(buffer, 0, byteRead);则完全没问题.
求教.
API上是说write(byte[] b)也是写入的b.length个字节.难道是这里的问题?如果是应该也不会大得这么离谱吧,我源文件是3M多,写出来后有时候是4M,有时是5M不等.
难道它是在inStream.read(buffer)的时候就有可能没有读满buffer.length个长度?
在client端获取后使用out.write(buffer);写出来的文件会比源文件大,而且大小不太固定.
如果我在client也换成out.write(buffer, 0, byteRead);则完全没问题.
求教.
API上是说write(byte[] b)也是写入的b.length个字节.难道是这里的问题?如果是应该也不会大得这么离谱吧,我源文件是3M多,写出来后有时候是4M,有时是5M不等.
难道它是在inStream.read(buffer)的时候就有可能没有读满buffer.length个长度?
解决方案 »
- 用xfire+spring整合可以访问/service/*服务,加了struts2就无法访问
- 项目被抢了,我该怎么办?
- Java爱好者,来分享、谈论下你们的团队理念,各抒己见,共同进步...
- 一个新框架LMVC
- 一个算法问题
- 如何实现动态加载网站模块?给点思路
- 请教一个关于Tomcat的公共库文件的问题。
- java.lang.OutOfMemoryError请教如何解决,我的web server是oracle servlet
- 请问有哪些工具可以对xml文档智能化处理的?
- 请高手帮我分析这个错误的原因,100分!
- 初学求教Struts2的登陆问题
- 如何实现struts2中访问一个jsp页面时,初始化数值。
从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。
"实际读取的字节数"会小于b.length
一般是
int i=in.read(buffer);
out.write(buffer,0,i);
他为什么不读满buffer.length呢?您能为我解答一下吗?
因为它一般是返回当时available的数据回来,怕你等得辛苦。最好去看看E文的JDK API说明。