最全关于RecyclerView的Adapter的notifyItemInserted()的一些分析,2024年最新互联网大厂100道Android面试题助你冲关金三银四

学习宝典

对我们开发者来说,一定要打好基础,随时准备战斗。不论寒冬是否到来,都要把自己的技术做精做深。虽然目前移动端的招聘量确实变少了,但中高端的职位还是很多的,这说明行业只是变得成熟规范起来了。竞争越激烈,产品质量与留存就变得更加重要,我们进入了技术赋能业务的时代。

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

很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候,总会遇到一些问题,比如学了一段时间感觉没有方向感,不知道该从那里入手去学习,对此我针对Android程序员,我这边给大家整理了一套学习宝典!包括不限于高级UI、性能优化、移动架构师、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

【算法合集】

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

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

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

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

  • @param observer the observer to register

  • @throws IllegalArgumentException the observer is null

  • @throws IllegalStateException the observer is already registered

*/_

public void registerObserver(T observer) {

if (observer == null) {

throw new IllegalArgumentException(“The observer is null.”);

}

synchronized(mObservers) {

if (mObservers.contains(observer)) {

throw new IllegalStateException(“Observer " + observer + " is already registered.”);

}

mObservers.add(observer);

}

}

_/**

  • Removes a previously registered observer. The observer must not be null and it

  • must already have been registered.

  • @param observer the observer to unregister

  • @throws IllegalArgumentException the observer is null

  • @throws IllegalStateException the observer is not yet registered

*/_

public void unregisterObserver(T observer) {

if (observer == null) {

throw new IllegalArgumentException(“The observer is null.”);

}

synchronized(mObservers) {

int index = mObservers.indexOf(observer);

if (index == -1) {

throw new IllegalStateException(“Observer " + observer + " was not registered.”);

}

mObservers.remove(index);

}

}

_/**

  • Remove all registered observers.

*/_

public void unregisterAll() {

synchronized(mObservers) {

mObservers.clear();

}

}

}

接着我们来看这个mObservable是在什么时候初始化的呢,我们回到setAdapter()这个方法

public void setAdapter(Adapter adapter) {

// bail out if layout is frozen

setLayoutFrozen(false);

setAdapterInternal(adapter, false, true);

requestLayout();

}

private void setAdapterInternal(Adapter adapter, boolean compatibleWithPrevious,

boolean removeAndRecycleViews) {

if (mAdapter != null) {

mAdapter.unregisterAdapterDataObserver(mObserver);

mAdapter.onDetachedFromRecyclerView(this);

}

if (!compatibleWithPrevious || removeAndRecycleViews) {

// end all running animations

if (mItemAnimator != null) {

mItemAnimator.endAnimations();

}

// Since animations are ended, mLayout.children should be equal to

// recyclerView.children. This may not be true if item animator’s end does not work as

// expected. (e.g. not release children instantly). It is safer to use mLayout’s child

// count.

if (mLayout != null) {

mLayout.removeAndRecycleAllViews(mRecycler);

mLayout.removeAndRecycleScrapInt(mRecycler);

}

// we should clear it here before adapters are swapped to ensure correct callbacks.

mRecycler.clear();

}

mAdapterHelper.reset();

final Adapter oldAdapter = mAdapter;

mAdapter = adapter;

if (adapter != null) {

adapter.registerAdapterDataObserver(mObserver);

adapter.onAttachedToRecyclerView(this);

}

if (mLayout != null) {

mLayout.onAdapterChanged(oldAdapter, mAdapter);

}

mRecycler.onAdapterChanged(oldAdapter, mAdapter, compatibleWithPrevious);

mState.mStructureChanged = true;

markKnownViewsInvalid();

}

在setAdapterInternal里面主要逻辑就是判断apdter是否为空,不为空的话调用mAdapter.unregisterAdapterDataObserver(mObserver);反注销掉mObserver 接着再调用adapter.registerAdapterDataObserver(mObserver); adapter.onAttachedToRecyclerView(this); 重新注册mObserver和依附到recycleView中。

确定了AdapterDataObservable这个类是什么时候初始化以后,接着我们再回到AdapterDataObservable 这个类

static class AdapterDataObservable extends Observable {

public boolean hasObservers() {

return !mObservers.isEmpty();

}

public void notifyChanged() {

// since onChanged() is implemented by the app, it could do anything, including

// removing itself from {@link mObservers} - and that could cause problems if

// an iterator is used on the ArrayList {@link mObservers}.

// to avoid such problems, just march thru the list in the reverse order.

for (int i = mObservers.size() - 1; i >= 0; i–) {

mObservers.get(i).onChanged();

}

}

public void notifyItemRangeChanged(int positionStart, int itemCount) {

notifyItemRangeChanged(positionStart, itemCount, null);

}

public void notifyItemRangeChanged(int positionStart, int itemCount, Object payload) {

// since onItemRangeChanged() is implemented by the app, it could do anything, including

// removing itself from {@link mObservers} - and that could cause problems if

// an iterator is used on the ArrayList {@link mObservers}.

// to avoid such problems, just march thru the list in the reverse order.

for (int i = mObservers.size() - 1; i >= 0; i–) {

mObservers.get(i).onItemRangeChanged(positionStart, itemCount, payload);

}

}

public void notifyItemRangeInserted(int positionStart, int itemCount) {

// since onItemRangeInserted() is implemented by the app, it could do anything,

// including removing itself from {@link mObservers} - and that could cause problems if

// an iterator is used on the ArrayList {@link mObservers}.

// to avoid such problems, just march thru the list in the reverse order.

for (int i = mObservers.size() - 1; i >= 0; i–) {

mObservers.get(i).onItemRangeInserted(positionStart, itemCount);

}

}

public void notifyItemRangeRemoved(int positionStart, int itemCount) {

// since onItemRangeRemoved() is implemented by the app, it could do anything, including

// removing itself from {@link mObservers} - and that could cause problems if

// an iterator is used on the ArrayList {@link mObservers}.

// to avoid such problems, just march thru the list in the reverse order.

for (int i = mObservers.size() - 1; i >= 0; i–) {

mObservers.get(i).onItemRangeRemoved(positionStart, itemCount);

}

}

public void notifyItemMoved(int fromPosition, int toPosition) {

for (int i = mObservers.size() - 1; i >= 0; i–) {

mObservers.get(i).onItemRangeMoved(fromPosition, toPosition, 1);

}

}

}

阅读了这个类的源码以后,我们惊喜地发现,这个类里面的notify方法是不是跟adapter里面的notify方法很相似,让我们来看看这个类里面的notify方法具体做了什么? 以insert为例。

public final void notifyItemInserted(int position) {

mObservable.notifyItemRangeInserted(position, 1);

}

调用了mObservable的notifyItemRangeInserted方法,也就是我们上面分析的AdapterDataObservable的notifyItemRangeInserted方法。看看这个方法具体做了什么。

public void notifyItemRangeInserted(int positionStart, int itemCount) {

// since onItemRangeInserted() is implemented by the app, it could do anything,

尾声

你不踏出去一步,永远不知道自己潜力有多大,千万别被这个社会套在我们身上的枷锁给捆住了,30岁我不怕,35岁我一样不怕,去做自己想做的事,为自己拼一把吧!不试试怎么知道你不行呢?

改变人生,没有什么捷径可言,这条路需要自己亲自去走一走,只有深入思考,不断反思总结,保持学习的热情,一步一步构建自己完整的知识体系,才是最终的制胜之道,也是程序员应该承担的使命。

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

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

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

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

T、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)**

[外链图片转存中…(img-s8tmV2MV-1715415349409)]

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

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值