OkHttpClient实例化解析

         OkHttpClient实例化解析

OkHttp3(OkHttp的最新版本)是Square公司推出一个用于Android和java平台的网络请求框架,是一个高效的Http/https客户端。其中OkHttpClient是这个框架进行网络请求的核心对象之一。本文重点介绍OkHttpClient对象的实例化方式。 从官方API中可以知道,OKHttpClient对象采用了典型的Builder设计模式,OkHttpClient对象有三种初始化方式 :
第一种方式:
// The singleton HTTP client.
public final OkHttpClient client = new OkHttpClient();
这种方式使用系统默认的参数来创建OkHttpClient对象
第二种方式:
// The singleton HTTP client.
public final OkHttpClient client = new OkHttpClient.Builder()
.addInterceptor(new HttpLoggingInterceptor())
.cache(new Cache(cacheDir, cacheSize))
.build();
这种方式支持用户自定义参数设置,比如日志拦截器,设置缓存目录和大小等参数。
第三种方式:
OkHttpClient eagerClient = client.newBuilder()
.readTimeout(500, TimeUnit.MILLISECONDS)
.build();
这种方式也是支持用户自定义参数设置。下面重点分析一下第二种自定参数设置和第三种自定义参数的区别。我们知道OkHttpClient对象是全局单例的,这种设计方式能够更好的实现对象实例的重用并且节省系统资源开销。每个OkHttpClient对象维护了一个属于自己的线程池和连接池。考虑如下情景:一个应用中需要有五个地方用到OkHttpClient对象,而且这五个OkHttpClient实例的参数设置不尽相同,以readTimeout为例,假如有两个OkHttpClient的readTimeout参数为500秒,另外三个的readTimeout参数为1000秒,这时我们可以这样创建OKHttpClient实例:
OkHttpClient eagerClient1 = client.newBuilder()
.readTimeout(500, TimeUnit.MILLISECONDS)
.build();

OkHttpClient eagerClient2 = client.newBuilder()
.readTimeout(1000, TimeUnit.MILLISECONDS)
.build();
这里表面上看我们似乎创建了两个OKHttpClient对象,实际上这两个对象内部的线程池和连接池都是一样的,只是readTimeout参数不一样。关于第二种创建OKHttpClient对象的方式来设置readTimeout是全局的参数设置,对所有实例都起作用的。

以上是个人对OKHttpClient对象创建的一点理解,如有不正确,请指正。

你可能感兴趣的:(Android)