我正在使用[Jobqueue]库使用与Volley的同步请求。一切都很好,但经过很长一段时间或在一段不确定的时间后执行了很多请求,我收到了这个错误:
Caused by: com.android.volley.VolleyError: java.lang.IllegalArgumentException: timeout < 0
at com.android.volley.NetworkDispatcher.run(NetworkDispatcher.java:141)
Caused by: java.lang.IllegalArgumentException: timeout < 0
at java.net.Socket.setSoTimeout(Socket.java:521)
at com.android.okhttp.internal.http.HttpTransport.discardStream(HttpTransport.java:193)
at com.android.okhttp.internal.http.HttpTransport.makeReusable(HttpTransport.java:170)
at com.android.okhttp.internal.http.HttpEngine.release(HttpEngine.java:445)
at com.android.okhttp.internal.http.AbstractHttpInputStream.endOfInput(AbstractHttpInputStream.java:86)
at com.android.okhttp.internal.http.HttpTransport$FixedLengthInputStream.read(HttpTransport.java:394)
at java.io.InputStream.read(InputStream.java:162)
at com.android.volley.toolbox.BasicNetwork.entityToBytes(BasicNetwork.java:238)
at com.android.volley.toolbox.BasicNetwork.performRequest(BasicNetwork.java:123)
at com.android.volley.NetworkDispatcher.run(NetworkDispatcher.java:112)
这个错误非常奇怪,因为一旦我收到此错误,请求就不再起作用了。 我已经尝试了很多东西,比如每个作业都有一个RequestQueue而不是一个应用程序实例RequestQueue,取消所有作业并重置RequestQueue中的作业和请求。
这是我如何使用Volley的同步请求的示例:
public class FetchBlacklistJob extends Job {
public static final String TAG = FetchBlacklistJob.class.getCanonicalName();
public FetchBlacklistJob(String groupId) {
super(new Params(Constants.JOB_PRIORITY.HIGH.getValue())
.addTags(TAG)
.setGroupId(groupId)
.singleInstanceBy(TAG)
.requireNetwork());
}
@Override
public void onAdded() {
}
@Override
public void onRun() throws Throwable {
RequestFuture<Blacklist> syncCallback = RequestFuture.newFuture();
GetBlacklistRequest request = new GetBlacklistRequest(currentBlacklist,
syncCallback, syncCallback);
syncCallback.setRequest(VolleyManager.getInstance().addRequest(request));
Blacklist response = syncCallback.get(VolleyManager.TIMEOUT, TimeUnit.MILLISECONDS);
if (response == null || response.getBlacklist() == null) {
Log.d(TAG, "response null, skipping...");
return;
}
DBUtils.saveBlacklist(response);
}
@Override
protected void onCancel(int cancelReason, @Nullable Throwable throwable) {
}
我忘了评论我的每个请求的超时时间为15秒,并且最大重试次数为0。
有什么想法吗?
答案 0 :(得分:2)
最后,由于谷歌库缓存请求,我修复了由于Retrofit取代Volley的错误,总是在同一个线程(主线程)中返回,并且似乎被同步请求阻止。
在这篇文章中做了更好的解释:https://solidgeargroup.com/android-priority-job-queue-background-tasks
答案 1 :(得分:0)
这可能是由于将相同的function fnc_start(){
navigator.mediaDevices.getUserMedia({audio: true, video: false});}
传递给多个请求引起的。
Volley跟踪DefaultRetryPolicy
内部的尝试次数和当前超时(mCurrentTimeoutMs
)。如果有多个请求,则DefaultRetryPolicy
呈指数增长,并且可能溢出为负数。