Android-Jetpack架构组件(二)带你了解Lifecycle(使用篇)


}
void start() {

}
void stop() {

}
}

再举个MVP中常见的情况,如下所示。

public class MainActivity extends AppCompatActivity {
private MyPresenter myPresenter;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myPresenter = new MyPresenter();
}

@Override
protected void onResume() {
super.onResume();
myPresenter.onResume();
}

@Override
protected void onPause() {
super.onPause();
myPresenter.onPause();
}
}

class MyPresenter{
void onResume() {

}
void onPause() {

}
}

这两个例子的写法已经很普遍了,实现起来也不难,但实际开发中,可能会有多个组件在Activity的生命周期中进行回调,这样Activity的生命周期的方法中可能就需要放大量的代码,这就使得它们难以维护。
还有一个问题是,如果我们在组件中做了耗时操作(比如在onStart方法),这种写法就无法保证组件在Activity或者Fragment停止之前完成启动。
因此我们需要一个能管理Activity和Fragment的生命周期的库,这个库就是Lifecycle。

2.如何使用Lifecycle

分别来介绍下依赖Lifecycle库和Lifecycle基本用法。

2.1 依赖Lifecycle库

官网给出的依赖代码如下所示:

dependencies {
def lifecycle_version = “2.0.0”

// ViewModel and LiveData
implementation “androidx.lifecycle:lifecycle-extensions: l i f e c y c l e v e r s i o n " / / a l t e r n a t i v e l y − j u s t V i e w M o d e l i m p l e m e n t a t i o n " a n d r o i d x . l i f e c y c l e : l i f e c y c l e − v i e w m o d e l : lifecycle_version" // alternatively - just ViewModel implementation "androidx.lifecycle:lifecycle-viewmodel: lifecycleversion"//alternativelyjustViewModelimplementation"androidx.lifecycle:lifecycleviewmodel:lifecycle_version” // For Kotlin use lifecycle-viewmodel-ktx
// alternatively - just LiveData
implementation “androidx.lifecycle:lifecycle-livedata: l i f e c y c l e v e r s i o n " / / a l t e r n a t i v e l y − L i f e c y c l e s o n l y ( n o V i e w M o d e l o r L i v e D a t a ) . S o m e U I / / A n d r o i d X l i b r a r i e s u s e t h i s l i g h t w e i g h t i m p o r t f o r L i f e c y c l e i m p l e m e n t a t i o n " a n d r o i d x . l i f e c y c l e : l i f e c y c l e − r u n t i m e : lifecycle_version" // alternatively - Lifecycles only (no ViewModel or LiveData). Some UI // AndroidX libraries use this lightweight import for Lifecycle implementation "androidx.lifecycle:lifecycle-runtime: lifecycleversion"//alternativelyLifecyclesonly(noViewModelorLiveData).SomeUI//AndroidXlibrariesusethislightweightimportforLifecycleimplementation"androidx.lifecycle:lifecycleruntime:lifecycle_version”

annotationProcessor “androidx.lifecycle:lifecycle-compiler: l i f e c y c l e v e r s i o n " / / F o r K o t l i n u s e k a p t i n s t e a d o f a n n o t a t i o n P r o c e s s o r / / a l t e r n a t e l y − i f u s i n g J a v a 8 , u s e t h e f o l l o w i n g i n s t e a d o f l i f e c y c l e − c o m p i l e r i m p l e m e n t a t i o n " a n d r o i d x . l i f e c y c l e : l i f e c y c l e − c o m m o n − j a v a 8 : lifecycle_version" // For Kotlin use kapt instead of annotationProcessor // alternately - if using Java8, use the following instead of lifecycle-compiler implementation "androidx.lifecycle:lifecycle-common-java8: lifecycleversion"//ForKotlinusekaptinsteadofannotationProcessor//alternatelyifusingJava8,usethefollowinginsteadoflifecyclecompilerimplementation"androidx.lifecycle:lifecyclecommonjava8:lifecycle_version”

// optional - ReactiveStreams support for LiveData
implementation “androidx.lifecycle:lifecycle-reactivestreams:$lifecycle_version” // For Kotlin use lifecycle-reactivestreams-ktx

// optional - Test helpers for LiveData
testImplementation “androidx.arch.core:core-testing:$lifecycle_version”
}

官网用的是AndroidX,因为使用AndroidX,可能会产生一些迁移的问题,这里的举例就不使用AndroidX,而是使用lifecycleandroid.arch.lifecycle库,如下所示。

dependencies {
def lifecycle_version = “1.1.1”

// 包含ViewModel和LiveData
implementation “android.arch.lifecycle:extensions: l i f e c y c l e v e r s i o n " / / 仅仅包含 V i e w M o d e l i m p l e m e n t a t i o n " a n d r o i d . a r c h . l i f e c y c l e : v i e w m o d e l : lifecycle_version" // 仅仅包含ViewModel implementation "android.arch.lifecycle:viewmodel: lifecycleversion"//仅仅包含ViewModelimplementation"android.arch.lifecycle:viewmodel:lifecycle_version” // For Kotlin use viewmodel-ktx
// 仅仅包含LiveData
implementation “android.arch.lifecycle:livedata: l i f e c y c l e v e r s i o n " / / 仅仅包含 L i f e c y c l e s i m p l e m e n t a t i o n " a n d r o i d . a r c h . l i f e c y c l e : r u n t i m e : lifecycle_version" // 仅仅包含Lifecycles implementation "android.arch.lifecycle:runtime: lifecycleversion"//仅仅包含Lifecyclesimplementation"android.arch.lifecycle:runtime:lifecycle_version”

annotationProcessor “android.arch.lifecycle:compiler: l i f e c y c l e v e r s i o n " / / F o r K o t l i n u s e k a p t i n s t e a d o f a n n o t a t i o n P r o c e s s o r / / 如果用 J a v a 8 , 用于替代 c o m p i l e r i m p l e m e n t a t i o n " a n d r o i d . a r c h . l i f e c y c l e : c o m m o n − j a v a 8 : lifecycle_version" // For Kotlin use kapt instead of annotationProcessor // 如果用Java8, 用于替代compiler implementation "android.arch.lifecycle:common-java8: lifecycleversion"//ForKotlinusekaptinsteadofannotationProcessor//如果用Java8,用于替代compilerimplementation"android.arch.lifecycle:commonjava8:lifecycle_version”

// 可选,ReactiveStreams对LiveData的支持
implementation “android.arch.lifecycle:reactivestreams:$lifecycle_version”

// 可选,LiveData的测试
testImplementation “android.arch.core:core-testing:$lifecycle_version”
}

实际上我们不需要全部把这些代码全写进build.gralde进去(当然全写进去也不会有什么错),因为Gradle默认是支持依赖传递的,不知道什么是依赖传递的看Android Gradle (二)签名配置和依赖管理这篇文章。
我们直接添加如下依赖就可以满足日常的工作,如果缺少哪个库,再去单独添加就好了。

添加这一句代码就依赖了如下的库。
eXj6eJ.png

2.2 Lifecycle基本用法

先不谈Activity和Fragment中如何使用,先举一个Lifecycle的简单例子。

public class MyObserver implements LifecycleObserver {
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
public void connectListener() {

}

@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
public void disconnectListener() {

}
}

myLifecycleOwner.getLifecycle().addObserver(new MyObserver());//1

新建一个MyObserver类,它实现了LifecycleObserver接口,说明MyObserver成为了一个Lifecycle的观察者。
然后在注释1处将MyObserver添加到LifecycleOwner中。LifecycleOwner是一个接口,其内部只有一个方法getLifecycle(),getLifecycle方法用于获取Lifecycle,这样就可以将MyObserver添加到Lifecycle中,当Lifecycle的生命周期发生变化时,MyObserver就会观察到,或者说是感知到。

如果使用是Java8 ,那么可以使用DefaultLifecycleObserver来替代LifecycleObserver:

class MyObserver implements DefaultLifecycleObserver {
@Override
public void onCreate(LifecycleOwner owner) {

}
}

除此之外,不要忘了在build.gradle添加 "androidx.lifecycle:common-java8:<version>"

3.Lifecycle应用举例

应用举例准备两个示例,一个是在Activity中使用,一个是在第一小节的MVP例子上进行改进。

3.1 Activity中使用

package com.example.lifecycledemo1;

import android.arch.lifecycle.Lifecycle;
import android.arch.lifecycle.LifecycleObserver;
import android.arch.lifecycle.OnLifecycleEvent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

public class MainActivity extends AppCompatActivity {

private static final String TAG = “MainActivity”;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
getLifecycle().addObserver(new MyObserver());//1
}

public class MyObserver implements LifecycleObserver{

@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
void onResume(){
Log.d(TAG, “Lifecycle call onResume”);
}
@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
void onPause(){
Log.d(TAG, “Lifecycle call onPause”);
}
}

@Override
protected void onResume() {
super.onResume();
Log.d(TAG, “onResume”);
}

@Override
protected void onPause() {
super.onPause();
Log.d(TAG, “onPause”);

}
}

先实现MyObserver,对ON_CREATE和ON_RESUME事件进行监听。因为在Android Support Library 26.1.0 及其之后的版本,Activity和Fragment已经默认实现了LifecycleOwner接口,所以在注释1处可以直接使用getLifecycle方法获取Lifecycle对象,这样MyObserver就可以观察MainActivity的生命周期变化了,LifecycleOwner可以理解为被观察者,MainActivity默认实现了LifecycleOwner接口,也就是说MainActivity是被观察者。
运行程序,打印的log如下所示。

D/MainActivity: onResume
D/MainActivity: Lifecycle call onResume
D/MainActivity: Lifecycle call onPause
D/MainActivity: onPause

只要在MainActivity的onCreate方法中添加MyObserver,那么MyObserver就可以观察到MainActivity的各个生命周期的变化。

3.2 MVP中使用

改写第一小节MVP的例子,先实现MyPresenter,如下所示。

public class MyPresenter implements IPresenter {
private static final String TAG = “test”;

@Override
public void onResume() {
Log.d(TAG, “Lifecycle call onResume”);
}

@Override
public void onPause() {
Log.d(TAG, “Lifecycle call onPause”);
}
}

interface IPresenter extends LifecycleObserver {

@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
void onResume();

@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
void onPause();
}

IPresenter接口继承自LifecycleObserver接口,MyPresenter又实现了IPresenter接口,这样MyPresenter成为了一个观察者。
接在在MainActivity中加入MyPresenter:

public class MainActivity extends AppCompatActivity {

private static final String TAG = “test”;
private IPresenter mPresenter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

最后

都说三年是程序员的一个坎,能否晋升或者提高自己的核心竞争力,这几年就十分关键。

技术发展的这么快,从哪些方面开始学习,才能达到高级工程师水平,最后进阶到Android架构师/技术专家?我总结了这 5大块;

我搜集整理过这几年阿里,以及腾讯,字节跳动,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 PDF(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。

Java语言与原理;
大厂,小厂。Android面试先看你熟不熟悉Java语言

高级UI与自定义view;
自定义view,Android开发的基本功。

性能调优;
数据结构算法,设计模式。都是这里面的关键基础和重点需要熟练的。

NDK开发;
未来的方向,高薪必会。

前沿技术;
组件化,热升级,热修复,框架设计

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

我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多

当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。

不出半年,你就能看出变化!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多

当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。

不出半年,你就能看出变化!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 25
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Jetpack架构组件从入门到精通》.pdf 是一本介绍Android Jetpack架构组件的书籍。Jetpack是Google官方提供的一套组件库,旨在帮助开发者更轻松地构建高质量的Android应用程序。 这本书从入门到精通地介绍了Jetpack架构组件的各个方面。首先,它详细解释了Jetpack的基本概念和使用方法。读者可以学习到Jetpack的核心组件,如ViewModel、LiveData、Room和Navigation等,以及它们在构建Android应用时的作用。 此外,这本书还介绍了Jetpack架构组件的一些高级技术和最佳实践。读者可以学习到如何使用WorkManager实现后台任务,如何使用DataBinding进行数据绑定,以及如何使用Paging构建分页列表等。 除了介绍Jetpack架构组件的基本用法和高级技术,这本书还提供了一些实际应用示例和案例分析。读者可以通过参考这些示例来更好地理解和应用Jetpack架构组件。 总之,《Jetpack架构组件从入门到精通》.pdf 是一本全面而深入地介绍Jetpack架构组件的书籍。无论是初学者还是有一定经验的开发者,都可以通过阅读这本书来提升自己在Android应用开发中使用Jetpack的能力。 ### 回答2: 《Jetpack架构组件从入门到精通》.pdf 是一本关于Jetpack架构组件的学习指南。Jetpack是Android开发中一套强大而且灵活的组件集合,旨在帮助开发者更轻松地构建高质量的Android应用程序。 该PDF文件从入门到精通地介绍了Jetpack架构组件的各个方面。首先,它向读者介绍了Jetpack的概念和使用场景,以帮助读者了解为什么应该学习和使用这些组件。 接下来,该指南逐一介绍了Jetpack架构组件的不同模块,包括ViewModel、LiveData、Room、Navigation等。它详细解释了每个组件的功能和用法,并通过实际示例演示了如何在项目中使用它们。 此外,该指南还提供了一些常见的最佳实践和实用技巧,以帮助读者更好地理解和运用Jetpack架构组件。它还包含了一些常见问题和解决方案,帮助读者避免在实践中遇到的常见问题。 最后,该指南还提供了一些参考资料和进一步学习资源,以帮助读者深入学习和掌握Jetpack架构组件。 总的来说,该《Jetpack架构组件从入门到精通》.pdf提供了一个全面而详尽的学习指南,帮助读者了解和应用Jetpack架构组件,使他们能够更高效地构建高质量的Android应用程序。无论是初学者还是有经验的开发者,该指南都是一个值得阅读和参考的资源。 ### 回答3: 《Jetpack架构组件从入门到精通》.pdf 是一本介绍Android Jetpack架构组件的电子书,它有助于开发者学习和理解如何使用这些组件来构建高质量、稳定的Android应用程序。 Jetpack架构组件是由谷歌开发的一组库,旨在帮助开发者简化Android应用的开发过程。它提供了一系列的工具和组件,涵盖了各个方面,包括界面设计、数据库、网络通信、数据绑定、后台处理等。 这本电子书从入门到精通地介绍了各个组件使用方法和最佳实践。它首先详细介绍了Jetpack架构组件的核心概念和优势,让读者了解为什么要使用这些组件。 然后,电子书逐一介绍了常用的Jetpack组件,如Lifecycle、ViewModel、Room、LiveData、Navigation等。每个组件都被详细地讲解,包括其作用、使用方法和示例代码。读者可以通过跟随书中的案例来实际操作和理解这些组件使用。 除了介绍各个组件,电子书还分享了一些进阶的使用技巧和开发经验。这些技巧包括如何优化应用性能、处理异步任务、实现数据缓存等。通过这些实用的技巧,开发者可以进一步提高应用的质量和用户体验。 总的来说,《Jetpack架构组件从入门到精通》.pdf 是一本很有价值的学习资料,对于想要深入学习和掌握Jetpack架构组件的开发者来说是必不可少的参考书籍。无论是初学者还是有经验的开发者,都可以从中获得知识和技能的提升。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值