💥 效果图
🔥 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移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
总结
【Android 详细知识点思维脑图(技能树)】
我个人是做Android开发,已经有十来年了,目前在某创业公司任职CTO兼系统架构师。虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
最后,赠与大家一句话,共勉!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
中…(img-1KLs57KV-1712684743077)]
总结
【Android 详细知识点思维脑图(技能树)】
[外链图片转存中…(img-Gutr6TOJ-1712684743077)]
我个人是做Android开发,已经有十来年了,目前在某创业公司任职CTO兼系统架构师。虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
[外链图片转存中…(img-UFDPP05a-1712684743077)]
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
最后,赠与大家一句话,共勉!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-NawCNUiT-1712684743078)]