Android OkHttp+Retrofit+Rxjava(2),2024年最新2024年华为面试题

💥 效果图


🔥 Rxjava

=========

RxJava使用了观察者模式建造者模式中的链式调用。

观察者模式:

Observable(被观察者)被Observer(观察者)订阅(Subscribe)之后,Observable在发出消息的时候会通知对应的Observer,并且,一个Observable可以有被多个Observer订阅。

链式调用:调用对应的方法对原对象进行处理后返回原对象,从而做到链式调用。

参与者:

  • Observable:被观察者,也就是消息的发送者

  • Observer:观察者,消息的接收者

  • Subscriber:订阅者,观察者的另一种表示

  • Scheduler:调度器,进行线程切换

RxJava当然是优秀而且强大的,有以下优势:

  • 具备响应式编程该有的特性。

  • 为异步而生,无需手动创建线程,并具备线程切换能力。

  • 支持链式调用,保证代码的简洁性。

  • 各种操作符,功能非常强大,满足各种业务需求。

  • 简化了异常的处理。

RxJava适用场景:网络请求、数据库读写、文件读写、定时任务等各种耗时操作需要通过异步来完成的操作都可以使用RxJava。

💥 添加依赖(新增)


implementation “io.reactivex.rxjava2:rxjava:2.2.6” // 必要rxjava依赖

implementation “io.reactivex.rxjava2:rxandroid:2.1.0” // 必要rxandrroid依赖,切线程时需要用到

implementation ‘com.squareup.retrofit2:adapter-rxjava2:2.5.0’ // 必要依赖,和rxjava结合必须用到

💥 修改请求接口


public interface IWanAndroidService {

String BASE_URL = “https://www.wanandroid.com/”;

//OkHttp+Retrofit

//OkHttp+Retrofit+RxJava

@GET(“banner/json”)

Observable<ResponseData<List>> homeBanner();

@POST(“user/register”)

@FormUrlEncoded

Observable<ResponseData> register(@FieldMap Map<String,String> map);

}

💥 设置OkHttp+Retrofit+RxJava


public Retrofit initRetrofitRxJava() {

if (retrofit == null) {

synchronized (NetworkManager.class) {

if (retrofit == null) {

retrofit = new Retrofit.Builder()

.client(initClient())//选填

.baseUrl(IWanAndroidService.BASE_URL)//必填

.addCallAdapterFactory(RxJava2CallAdapterFactory.create())//新增网络请求适配器

.addConverterFactory(GsonConverterFactory.create())//选填(数据转换器,解析)

.build();

}

}

}

return retrofit;

}

💥 进行网络请求


NetworkManager.getInstance().initRetrofitRxJava()

.create(IWanAndroidService.class)

.homeBanner()

.subscribeOn(Schedulers.io())//切换到IO线程

.observeOn(AndroidSchedulers.mainThread())//切换到主线程

// 添加订阅

.subscribe(listResponseData -> {

//请求成功

if (listResponseData != null) {

MLog.e(listResponseData.getData().get(0).toString());

binding.loginTvContent.setText(listResponseData.getData().get(0).toString());

}

}, throwable -> {

//请求失败

MLog.e(throwable.getMessage());

});

💥 效果图


💥 进一步封装


由于请求过于繁琐,咱们试着复进一步封装。

🌀 统一异常处理(自定义ApiException)

public class ApiException extends Exception {

//未知错误

public static final int UNKNOWN = 1000;

//解析错误

public static final int PARSE_ERROR = 1001;

//网络错误/连接错误

public static final int NETWORK_ERROR = 1002;

private int code;

private String displayMessage;

public ApiException(int code, String displayMessage) {

this.code = code;

this.displayMessage = displayMessage;

}

public int getCode() {

return code;

}

public void setCode(int code) {

this.code = code;

}

public String getDisplayMessage() {

return displayMessage;

}

public void setDisplayMessage(String displayMessage) {

this.displayMessage = displayMessage;

}

public static ApiException handleException(Throwable e) {

ApiException ex;

if (e instanceof JsonParseException

|| e instanceof JSONException

|| e instanceof ParseException) {

//解析错误

ex = new ApiException(PARSE_ERROR, e.getMessage());

return ex;

} else if (e instanceof ConnectException) {

//网络错误

ex = new ApiException(NETWORK_ERROR, e.getMessage());

return ex;

} else if (e instanceof UnknownHostException || e instanceof SocketTimeoutException) {

//连接错误

ex = new ApiException(NETWORK_ERROR, e.getMessage());

return ex;

} else {

//未知错误

ex = new ApiException(UNKNOWN, e.getMessage());

return ex;

}

}

}

🌀 统一异常处理(实现Consumer<Throwable>接口)

public abstract class ErrorConsumer implements Consumer {

@Override

public void accept(@NotNull Throwable throwable) throws Exception {

//对异常进行处理

ApiException exception;

if (throwable instanceof ApiException) {

exception = (ApiException) throwable;

} else {

exception = ApiException.handleException(throwable);

}

//调用error方法

error(exception);

}

//使用时实现error方法即可。

protected abstract void error(ApiException e);

}

🌀 响应转换处理

public class ResponseTransformer implements ObservableTransformer<ResponseData, T> {

public ResponseTransformer() {

}

public static  ResponseTransformer obtain(){

return new ResponseTransformer<>();

}

@NotNull

@Override

public ObservableSource apply(@NotNull Observable<ResponseData> upstream) {

return upstream.onErrorResumeNext(new Function<Throwable, ObservableSource<? extends ResponseData>>() {

@Override

public ObservableSource<? extends ResponseData> apply(@NotNull Throwable throwable) throws Exception {

return Observable.error(ApiException.handleException(throwable));

}

}).flatMap(new Function<ResponseData, ObservableSource>() {

@Override

public ObservableSource apply(@NotNull ResponseData responseData) throws Exception {

//请求成功,开始处理你的逻辑吧

if (0==responseData.getErrorCode()) {

if (null!=responseData.getData()) {

return Observable.just(responseData.getData());

} else {

//有可能存在返回的数据结果为ull,直接传Null会产生异常。

//用过反射创建一个没有内容的数据实例。

return Observable.just(responseData.getData());

}

}

//请求异常

return Observable.error(new ApiException(responseData.getErrorCode(), responseData.getErrorMsg()));

}

}).subscribeOn(Schedulers.io()).observeOn(AndroidSchedulers.mainThread());

}

}

🌀 封装后使用

数据拿到。

🔥 Hilt(Jetpack成员)

==================

在 Android 上使用Hilt进行依赖注入。Hilt 建立在 Dagger 之上,它提供了一种将 Dagger 依赖注入合并到 Android 应用程序中的标准方法。

官方文档最为致命

💥 添加依赖(新增)


implementation ‘com.google.dagger:hilt-android:2.40.1’

annotationProcessor ‘com.google.dagger:hilt-compiler:2.40.1’

💥 Hilt Gradle plugin


🌀 build.gradle(Project)

buildscript {

repositories {

google()

mavenCentral()

}

dependencies {

classpath ‘com.google.dagger:hilt-android-gradle-plugin:2.40.1’

}

}

🌀 build.gradle(Module)

apply plugin: ‘dagger.hilt.android.plugin’

🌀 Hilt Application

所有使用 Hilt 的应用程序都必须包含一个用 @HiltAndroidApp 注释的 Application 类。

创建Application

import android.app.Application;

import dagger.hilt.android.HiltAndroidApp;

@HiltAndroidApp

public class App extends Application {

}

设置AndroidManifest

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android=“http://schemas.android.com/apk/res/android”

package=“com.scc.wanandroid”>

<application

android:name=“.App”

…>

准备工作做完了,开始使用Hilt搭建网络框架

💥 设置OkHttp+Retrofit+RxJava+Hilt


🌀 创建NetworkModule用来初始化

@InstallIn(SingletonComponent.class)

@Module

public class NetworkModule {

private static int TIME_OUT = 30; //30秒超时断开连接

@Provides

@Singleton

OkHttpClient providesOkHttpClient(){

HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor(new HttpLoggingInterceptor.Logger() {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

总结

【Android 详细知识点思维脑图(技能树)】

我个人是做Android开发,已经有十来年了,目前在某创业公司任职CTO兼系统架构师。虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

最后,赠与大家一句话,共勉!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img
中…(img-1KLs57KV-1712684743077)]

总结

【Android 详细知识点思维脑图(技能树)】

[外链图片转存中…(img-Gutr6TOJ-1712684743077)]

我个人是做Android开发,已经有十来年了,目前在某创业公司任职CTO兼系统架构师。虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-UFDPP05a-1712684743077)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

最后,赠与大家一句话,共勉!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-NawCNUiT-1712684743078)]

  • 10
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值