初识LiveData

Architecture Components推出1.0稳定版后直接让SupportActivity实现了LifecycleOwner接口,不需要我们先以前一样继承LivecycleActivity了,只要是SupportActivity的子类都是一个LifecycleOwner

public class SupportActivity extends Activity implements LifecycleOwner {
  //...
}

几个特性

1.如果liveData中已经持有数据,那么 后面添加进来的observer会立即触发onChange(T t)方法,把前面的数据发送出去

public interface Observer<T> {
    void onChanged(@Nullable T t);
}

2.设置数据的如下两种方式

protected void postValue(T value) {//....}
protected void setValue(T value) {//....}

setValue(T value)要求在Ui线程中调用,如果在子线程调用会报错。在子线程需要更新数据的话要调用postValue(T value),其实这个方法实际上也是调用了setValue方法的

protected void postValue(T value) {
     //...
        ArchTaskExecutor.getInstance().postToMainThread(mPostValueRunnable);
    }

可以看到,在最后他将一个Runnable调度到主线程去执行,mPostValueRunnable如下

public void run() {
            //...
            setValue((T) newValue);
        }

postValue(T value)内部切换线程就一定会增加延迟,所以就印证文档中说的,在主线程执行如下代码,liveData中的数据会先变为b然后变为a

liveData.postValue("a");
liveData.setValue("b");

那么照上面所说,postValue(T value)有一定延迟的话,短时间内一直触发该方法会不会造成任务堆叠呢?我们再来看一看源码

protected void postValue(T value) {
        boolean postTask;
        synchronized (mDataLock) {
            postTask = mPendingData == NOT_SET;
            mPendingData = value;
        }
        if (!postTask) {
            return;
        }
        ArchTaskExecutor.getInstance().postToMainThread(mPostValueRunnable);
    }

看以看出,postTask为假即 mPendingData != NOT_SET时就不会产生新的调度了,NOT_SET就是一个Object,而mPendingData 在初始化时赋值为NOT_SET

//初始化
private static final Object NOT_SET = new Object();
private volatile Object mPendingData = NOT_SET;

在调用postValuemPendingData 就已经不是NOT_SET了,因此如果一直调用postValue的话是不会产生任务堆叠的。那什么时候postValue才重新有效呢?再来看看被调度的Runnable

public void run() {
            Object newValue;
            synchronized (mDataLock) {
                newValue = mPendingData;
                mPendingData = NOT_SET;
            }
            //noinspection unchecked
            setValue((T) newValue);
        }
mPendingData = NOT_SET;

对,就是这时候postValue(T value)重新有效了,所以循环postValue(T value)的效果是每几个调用只有一个有效,上一个调度完成才会产生下一个,并不会堆叠。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,828评论 19 139
  • Java SE 基础: 封装、继承、多态 封装: 概念:就是把对象的属性和操作(或服务)结合为一个独立的整体,并尽...
    Jayden_Cao阅读 6,423评论 0 8
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,486评论 11 349
  • 个人笔记,方便自己查阅使用 Contents Java LangAssignment, ReferenceData...
    freenik阅读 5,237评论 0 6
  • 转至元数据结尾创建: 董潇伟,最新修改于: 十二月 23, 2016 转至元数据起始第一章:isa和Class一....
    40c0490e5268阅读 5,872评论 0 9

友情链接更多精彩内容