2024年最全Android LiveData 使用详解,阿里面试问面试官什么问题

面试宝典

面试必问知识点、BATJ历年历年面试真题+解析

学习经验总结

(一)调整好心态
心态是一个人能否成功的关键,如果不调整好自己的心态,是很难静下心来学习的,尤其是现在这么浮躁的社会,大部分的程序员的现状就是三点一线,感觉很累,一些大龄的程序员更多的会感到焦虑,而且随着年龄的增长,这种焦虑感会越来越强烈,那么唯一的解决办法就是调整好自己的心态,要做到自信、年轻、勤奋。这样的调整,一方面对自己学习有帮助,另一方面让自己应对面试更从容,更顺利。

(二)时间挤一挤,制定好计划
一旦下定决心要提升自己,那么再忙的情况下也要每天挤一挤时间,切记不可“两天打渔三天晒网”。另外,制定好学习计划也是很有必要的,有逻辑有条理的复习,先查漏补缺,然后再系统复习,这样才能够做到事半功倍,效果才会立竿见影。

(三)不断学习技术知识,更新自己的知识储备
对于一名程序员来说,技术知识方面是非常重要的,可以说是重中之重。**要面试大厂,自己的知识储备一定要非常丰富,若缺胳膊少腿,别说在实际工作当中,光是面试这一关就过不了。**对于技术方面,首先基础知识一定要扎实,包括自己方向的语言基础、计算机基础、算法以及编程等等。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

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

在实际当中,我们的做法是:实现 Factory 接口,重写 create 方法,在create 方法里面调用相应的构造函数,返回相应的实例。

public class TestViewModel extends ViewModel {

private final String mKey;

private MutableLiveData mNameEvent = new MutableLiveData<>();

public MutableLiveData getNameEvent() {

return mNameEvent;

}

public TestViewModel(String key) {

mKey = key;

}

public static class Factory implements ViewModelProvider.Factory {

private String mKey;

public Factory(String key) {

mKey = key;

}

@Override

public T create(Class modelClass) {

return (T) new TestViewModel(mKey);

}

}

public String getKey() {

return mKey;

}

}

ViewModelProviders.of(this, new TestViewModel.Factory(mkey)).get(TestViewModel.class)


自定义 Livedata


Livedata 主要有几个方法

  1. observe

  2. onActive

  3. onInactive

  4. observeForever

void observe (LifecycleOwner owner, Observer observer)

Adds the given observer to the observers list within the lifespan of the given owner. The events are dispatched on the main thread. If LiveData already has data set, it will be delivered to the observer.

void onActive ()

Called when the number of active observers change to 1 from 0.

This callback can be used to know that this LiveData is being used thus should be kept up to date.

当回调该方法的时候,表示该 liveData 正在背使用,因此应该保持最新

void onInactive ()

Called when the number of active observers change from 1 to 0.

This does not mean that there are no observers left, there may still be observers but their lifecycle states aren’t STARTED or RESUMED (like an Activity in the back stack).

You can check if there are observers via hasObservers().

当该方法回调时,表示他所有的 obervers 没有一个状态处理 STARTED 或者 RESUMED,注意,这不代表没有 observers。

Void observeForever

跟 observe 方法不太一样的是,它在 Activity 处于 onPause ,onStop, onDestroy 的时候,都可以回调 obsever 的 onChange 方法,但是有一点需要注意的是,我们必须手动 remove obsever,否则会发生内存泄漏。

这里我们以观察网络状态变化为例子讲解

  1. 首先我们自定义一个 Class NetworkLiveData,继承 LiveData,重写它的 onActive 方法和 onInactive 方法

  2. 在 onActive 方法中,我们注册监听网络变化的广播,即ConnectivityManager.CONNECTIVITY_ACTION。在 onInactive 方法的时候,我们注销广播。

public class NetworkLiveData extends LiveData {

private final Context mContext;

static NetworkLiveData mNetworkLiveData;

private NetworkReceiver mNetworkReceiver;

private final IntentFilter mIntentFilter;

private static final String TAG = “NetworkLiveData”;

public NetworkLiveData(Context context) {

mContext = context.getApplicationContext();

mNetworkReceiver = new NetworkReceiver();

mIntentFilter = new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION);

}

public static NetworkLiveData getInstance(Context context) {

if (mNetworkLiveData == null) {

mNetworkLiveData = new NetworkLiveData(context);

}

return mNetworkLiveData;

}

@Override

protected void onActive() {

super.onActive();

Log.d(TAG, “onActive:”);

mContext.registerReceiver(mNetworkReceiver, mIntentFilter);

}

@Override

protected void onInactive() {

super.onInactive();

Log.d(TAG, "onInactive: ");

mContext.unregisterReceiver(mNetworkReceiver);

}

private static class NetworkReceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent) {

ConnectivityManager manager = (ConnectivityManager) context

.getSystemService(Context.CONNECTIVITY_SERVICE);

NetworkInfo activeNetwork = manager.getActiveNetworkInfo();

getInstance(context).setValue(activeNetwork);

}

}

}

这样,当我们想监听网络变化的时候,我们只需要调用相应的 observe 方法即可,方便又快捷。

NetworkLiveData.getInstance(this).observe(this, new Observer() {

@Override

public void onChanged(@Nullable NetworkInfo networkInfo) {

Log.d(TAG, “onChanged: networkInfo=” +networkInfo);

}

});


https://www.jianshu.com/p/4b7945475a6f

共享数据


Fragment Activity 之间共享数据

我们回过头来再来看一下 ViewModelProvider 的 of 方法,他主要有四个方法,分别是

  1. ViewModelProvider of(@NonNull Fragment fragment)

  2. ViewModelProvider of(@NonNull FragmentActivity activity)

  3. ViewModelProvider of(@NonNull Fragment fragment, @Nullable Factory factory)

  4. ViewModelProvider of(@NonNull FragmentActivity activity, @Nullable Factory factory)

1,2 方法之间的主要区别是传入 Fragment 或者 FragmentActivity。而我们知道,通过 ViewModel of 方法创建的 ViewModel 实例, 对于同一个 fragment 或者 fragmentActivity 实例,ViewModel 实例是相同的,因而我们可以利用该特点,在 Fragment 中创建 ViewModel 的时候,传入的是 Fragment 所依附的 Activity。因而他们的 ViewModel 实例是相同的,从而可以做到共享数据。

// LiveDataSampleActivity(TestFragment 依赖的 Activity)

mTestViewModel = ViewModelProviders.of(this, new TestViewModel.Factory(mkey)).get(TestViewModel.class);

MutableLiveData nameEvent = mTestViewModel.getNameEvent();

nameEvent.observe(this, new Observer() {

@Override

public void onChanged(@Nullable String s) {

Log.i(TAG, "onChanged: s = " + s);

mTvName.setText(s);

}

});

// TestFragment 中

mViewModel = ViewModelProviders.of(mActivity).get(TestViewModel.class);

mViewModel.getNameEvent().observe(this, new Observer() {

@Override

public void onChanged(@Nullable String s) {

Log.d(TAG, “onChanged: s =” + s + " mViewModel.getKey() =" + mViewModel.getKey());

mTvName.setText(s);

boolean result = mViewModel == ((LiveDataSampleActivity) mListener).mTestViewModel;

Log.d(TAG, “onChanged: s result =” + result);

}

});

这样,LiveDataSampleActivity 和 TestFragment 中的 ViewModel 是同一个实例。即 Activity 和 Fragment 共享数据。

全局共享数据

说到全局共享数据,我们想一下我们的应用全景,比如说我的账户数据,这个对于整个 App 来说,肯定是全局共享的。有时候,当我们的数据变化的时候,我们需要通知我们相应的界面,刷新 UI。如果用传统的方式来实现,那么我们一般才采取观察者的方式来实现,这样,当我们需要观察数据的时候,我们需要添加 observer,在界面销毁的时候,我们需要移除 observer。

但是,如果我们用 LiveData 来实现的话,它内部逻辑都帮我们封装好了,我们只需要保证 AccountLiveData 是单例的就ok,在需要观察的地方调用 observer 方法即可。也不需要手动移除 observer,不会发生内存泄漏,方便快捷。

这里 AccountLiveData 的实现就不贴出来了,可以参考上面的 NetworkLiveData 实现


小结


这里说一点关于 LiveData 与 ViewModel 的应用场景,我尽量说得通俗一点,不要说得那么官方,这样对新手很难理解。

觉得不错的,请点个赞,让我们看到你们的欢呼声。你们的支持就是我写作的最大动力。

  1. LiveData 内部已经实现了观察者模式,如果你的数据要同时通知几个界面,可以采取这种方式

  2. 我们知道 LiveData 数据变化的时候,会回调 Observer 的 onChange 方法,但是回调的前提是 lifecycleOwner(即所依附的 Activity 或者 Fragment) 处于 started 或者 resumed 状态,它才会回调,否则,必须等到 lifecycleOwner 切换到前台的时候,才回调。

  3. 因此,这对性能方面确实是一个不小的提升。但是,对于你想做一些类似与在后台工作的(黑科技), liveData 就不太适合了,你可以使用 observeForever 方法,或者自己实现观察者模式去吧。

Lifecycle,LiveData, ViewModel 的基本使用到此已经讲解完毕,想了解他们的实现原理的话可以阅读这两篇文章。

Android lifecyle 源码解剖

Android livedata 源码解剖

github sample 地址: ArchiteComponentsSample

推荐阅读


Android 启动优化(一) - 有向无环图

Android 启动优化(二) - 拓扑排序的原理以及解题思路

结尾

最后,针对上面谈的内容,给大家推荐一个Android资料,应该对大家有用。

首先是一个知识清单:(对于现在的Android及移动互联网来说,我们需要掌握的技术)

泛型原理丶反射原理丶Java虚拟机原理丶线程池原理丶
注解原理丶注解原理丶序列化
Activity知识体系(Activity的生命周期丶Activity的任务栈丶Activity的启动模式丶View源码丶Fragment内核相关丶service原理等)
代码框架结构优化(数据结构丶排序算法丶设计模式)
APP性能优化(用户体验优化丶适配丶代码调优)
热修复丶热升级丶Hook技术丶IOC架构设计
NDK(c编程丶C++丶JNI丶LINUX)
如何提高开发效率?
MVC丶MVP丶MVVM
微信小程序
Hybrid
Flutter

接下来是资料清单:(敲黑板!!!


1.数据结构和算法

2.设计模式

3.全套体系化高级架构视频;七大主流技术模块,视频+源码+笔记

4.面试专题资料包(怎么能少了一份全面的面试题总结呢~)

不论遇到什么困难,都不应该成为我们放弃的理由!共勉~

如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

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

级架构视频**;七大主流技术模块,视频+源码+笔记

[外链图片转存中…(img-R4E7c5mq-1715876077292)]

4.面试专题资料包(怎么能少了一份全面的面试题总结呢~)

[外链图片转存中…(img-1AG289MW-1715876077292)]

不论遇到什么困难,都不应该成为我们放弃的理由!共勉~

如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。

[外链图片转存中…(img-sZDJS9dj-1715876077292)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

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

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值