Java 为什么我一次只能从okhttp.Response输入流读取2048字节?
我正在使用OkHttp GET请求下载文件:Java 为什么我一次只能从okhttp.Response输入流读取2048字节?,java,android,networking,okhttp,okio,Java,Android,Networking,Okhttp,Okio,我正在使用OkHttp GET请求下载文件: import com.squareup.okhttp.OkHttpClient; import com.squareup.okhttp.Request; import com.squareup.okhttp.Response; ... OkHttpClient okClient = new OkHttpClient(); Request request = Request.Builder().url(url).get(); Response resp
import com.squareup.okhttp.OkHttpClient;
import com.squareup.okhttp.Request;
import com.squareup.okhttp.Response;
...
OkHttpClient okClient = new OkHttpClient();
Request request = Request.Builder().url(url).get();
Response response = okClient.newCall(request).execute();
我从响应体中读取数据,并用缓冲区大小为4096的BufferedInputStream
对其进行修饰:
BufferedInputStream in = new BufferedInputStream(response.body().byteStream(), 4096);
但是,当我尝试从缓冲区读取时,第一次读取返回1179字节。之后,我一次只能读取2048字节:
byte[] buffer = new byte[4096];
while (true) {
int bytesRead = in.read(buffer); //bytesRead is always 2048, except the first read
if (bytesRead == -1) break;
}
几个相关问题:
InputStream
中的读取分页为2048字节的大小,而不是BufferedInputStream
包装指定的值OkHttpClient
配置为从缓冲区读取超过2048个字节BufferedInputStream
以找出它为什么不将两个页面连接在一起
来自OkHttp的InputStream
正在处理2048个块,因为它使用它们的池来保存分配
有没有办法将OkHttpClient配置为从缓冲区读取2048字节以上的数据
没有
根据您正在做的事情,通常使用
response.body().source()
中的BufferedSource
比使用BufferedInputStream
会更好。您可以在上了解更多关于它们的信息。谢谢您的解释,杰克。我不知道source()方法,我将查看Okio。在这种情况下,我们如何下载文件?从我的服务下载10MB需要很长时间别管我的问题,使用这个()解决了速度问题。