关于okhttp的简单使用和原理解析

本文介绍了OkHttp框架的流行原因,重点讲解了其简化请求过程、性能优化(如连接池和缓存)以及底层实现,包括请求队列、分发器和拦截器的作用。
摘要由CSDN通过智能技术生成

安卓客户端面试常问问题关于框架的底层源码;

okhttp是一个非常火爆的框架,首先看看他为什么火爆或者说使用这个框架能给我们带来什么?是代码的简洁还是说性能方面得到优化了呢:

  • 允许连接到同一个主机地址的所有请求,提高请求效率
  • 共享Socket,减少对服务器的请求次数
  • 通过连接池,减少了请求延迟
  • 缓存响应数据来减少重复的网络请求
  • 减少了对数据流量的消耗
  • 自动处理GZip压缩

(摘录自官网)

简单来说就是降低了请求的复杂程度性能效率有一定优化

下面直接开始使用:
请求部分:Request使用步骤:

  1. 创建okhttpclient对象;
  2. 创建request对象(指定你要访问的内容,方式等等);相当于一个封装然后传入到指定方法内,进行处理
  3. 利用okhttpclient对象的newcall方法对该requeset创建一个Call对象;
  4. 调用call对象的enqueue方法并且传入回调对象callback;算是匿名内部类,然后重写访问成功和失败的逻辑;
String url = "http://wwww.baidu.com";
OkHttpClient okHttpClient = new OkHttpClient();
Request request = new Request.Builder()
    .url(url)
    .get()	//默认就是GET请求,可以省略
    .build();
Call call = okHttpClient.newCall(request);
call.enqueue(new Callback() {
    @Override
    public void onFailure(Call call, IOException e) {
        Log.d(TAG, "onFailure: ");
    }
    @Override
    public void onResponse(Call call, Response response) throws IOException {
    	//response.body().string() 获得服务器返回的数据
        Log.d(TAG, "onResponse: " + response.body().string());
    }
});

这个简单get方法,框架使用比如post异步等等高级操作还有很多但不是我想说的重点,下面带大家了解一下具体的底层实现原理。

首先请求是通过call的队列enqueue方法实现的,这个方法其实就是发起一个请求,但是这个请求肯定不会随意就发送的,当有多个的时候该怎么处理呢?

这时候就需要一个分发器的东西        他是okhttp用于管理你发出的请求的类;并通过execute()及enqueue()方法对同步或异步请求进行处理;最后返回结果的时候,对于多个返回结果也需要使用一个拦截器去获取你这个请求指定的返回结果。

具体拦截器的一些功能可以自己在网络查找,说太深了大家也记不住 ,只需要记住大致实现逻辑,结合具体代码去看就行。

拦截器模式的话使得我们后期拓展性非常强,可以对返回消息机型操作处理或者是自定义自己想要的拦截器

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值