OkHttp 异步网络请求流程

 直接上码:

	public void doGet(View view) {

		Request request = new Request.Builder().url(BASEURL + "login")
				.get().cacheControl(CacheControl.FORCE_NETWORK).build();
		okHttpClient.newCall(request).enqueue(new Callback() {
			@Override
			public void onFailure(Call call, IOException e) {
				Log.e(TAG, "onFailure: " + call.toString());
			}

			@Override
			public void onResponse(Call call, Response response) throws IOException {
				Log.e(TAG, "onResponse: " + response.body().string());
			}
		});
	}public void doGet(View view) {

		Request request = new Request.Builder().url(BASEURL + "login")
				.get().cacheControl(CacheControl.FORCE_NETWORK).build();
		okHttpClient.newCall(request).enqueue(new Callback() {
			@Override
			public void onFailure(Call call, IOException e) {
				Log.e(TAG, "onFailure: " + call.toString());
			}

			@Override
			public void onResponse(Call call, Response response) throws IOException {
				Log.e(TAG, "onResponse: " + response.body().string());
			}
		});
	}

跟使用同步方法是相差一个enqueque()方法:

  @Override public void enqueue(Callback responseCallback) {
    synchronized (this) {
      if (executed) throw new IllegalStateException("Already Executed");
      executed = true;
    }
    captureCallStackTrace();
    eventListener.callStart(this);
    client.dispatcher().enqueue(new AsyncCall(responseCallback)); 创建一个ASyncCall 对象交给 dispather
  }

 dispathcher.enqueque(...) :

synchronized void enqueue(AsyncCall call) {
判断网络请求进行中数量是否大于最大请求和 ip(域名)相同不超过maxRequestsPerHost 
 if (runningAsyncCalls.size() < maxRequests && runningCallsForHost(call) < maxRequestsPerHost) {
runningAsyncCalls.add(call);//符合 添加到异步运行容器中
 executorService().execute(call);// 然后线程池调度器去执行 call 
}
else 
{ 
readyAsyncCalls.add(call); //不符合添加到等待队列中
 }
 }
因为是使用executorService.execute(..) 参数是call  所以AsyncCall必然是继承Runable子类或者实现了Runable.

AsyncCall 继承的是 NamedRunable(Runable的子类) 并实现了抽象execute()方法

 @Override protected void execute() {
      boolean signalledCallback = false;
      try {
        Response response = getResponseWithInterceptorChain(); 去执行网络请求
        if (retryAndFollowUpInterceptor.isCanceled()) { 是否取消
          signalledCallback = true;
          responseCallback.onFailure(RealCall.this, new IOException("Canceled"));错误(取消)回调
        } else {
          signalledCallback = true;
          responseCallback.onResponse(RealCall.this, response);成功回调
        }
      } catch (IOException e) {
        if (signalledCallback) {
          // Do not signal the callback twice!
          Platform.get().log(INFO, "Callback failure for " + toLoggableString(), e);
        } else {
          eventListener.callFailed(RealCall.this, e);
          responseCallback.onFailure(RealCall.this, e);
        }
      } finally {
        client.dispatcher().finished(this); 这里是从异步容器中移除并判断是否有read..容器中网络请求有
添加到线程调度器中执行,没有或者大于最大请求 good bye
 }
    }
  }


Dispather: 存放AsyncCall和并使 AsyncCall 的中网络请求方法在子线程执行
流程图如下:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值