Android通用的Adapter,或许你用我这一个就够了,特殊渠道拿到阿里大厂面试真题

}

private class RecyclerAdapter extends RecyclerView.Adapter<RecyclerAdapter.Holder> {

private LayoutInflater mInflater;

private Context mContext;

private List mData;

private int mLayoutId;

public RecyclerAdapter(Context context, List data, int layoutId) {

mInflater = LayoutInflater.from(context);

this.mContext = context;

this.mData = data;

this.mLayoutId = layoutId;

}

@Override

public Holder onCreateViewHolder(ViewGroup parent, int viewType) {

View view = mInflater.inflate(mLayoutId, parent, false);

return new Holder(view);

}

@Override

public void onBindViewHolder(Holder holder, int position) {

holder.tv.setText(mData.get(position));

}

@Override

public int getItemCount() {

return mData.size();

}

class Holder extends RecyclerView.ViewHolder {

public TextView tv;

public Holder(View itemView) {

super(itemView);

tv = itemView.findViewById(R.id.tv);

}

}

}

三、ListView、RecyclerView Adapter一些共性分析
  1. 要显示的条目个数

  2. 要显示和条目对应的类型

  3. ListView、RecyclerView中,总共有多少个条目类型

  4. 根据不同的条目类型加载不同的View

  5. ListView复用条目convertView,RecyclerView自带ViewHoler复用

四、抽取RecyclerView、ListView、GridView适配器的基类

由于要通用RecyclerView、ListView、GridView只能将RecyclerView.Adapter和ListAdapter,SpinnerAdapter

这些都给实现了。里面也没多少个方法,其实也是很简单。至于一些方法的实现我考贝BaseAdapter的实现,

大家可以去看看BaseAdapter的源码。

public class BaseAdapter extends RecyclerView.Adapter implements ListAdapter, SpinnerAdapter {

private final DataSetObservable mDataSetObservable = new DataSetObservable();

// RecyclerView========================================================================

@Override

public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

return null;

}

// RecyclerView

@Override

public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {

}

// RecyclerView

@Override

public int getItemCount() {

return 0;

}

// RecyclerView========================================================================

// ListView========================================================================

@Override

public boolean areAllItemsEnabled() {

return true;

}

@Override

public boolean isEnabled(int position) {

return true;

}

@Override

public void registerDataSetObserver(DataSetObserver observer) {

mDataSetObservable.registerObserver(observer);

}

@Override

public void unregisterDataSetObserver(DataSetObserver observer) {

mDataSetObservable.unregisterObserver(observer);

}

public void notifyListDataSetChanged() {

mDataSetObservable.notifyChanged();

}

@Override

public Object getItem(int position) {

return null;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

return null;

}

@Override

public int getViewTypeCount() {

return 1;

}

@Override

public int getItemViewType(int position) {

return 0;

}

@Override

public int getCount() {

return 0;

}

@Override

public boolean isEmpty() {

return getCount() == 0;

}

@Override

public View getDropDownView(int position, View convertView, ViewGroup parent) {

return getView(position, convertView, parent);

}

}

五、抽取支持ListView、 GridView、 RecyclerView多条目的共性

public interface QuickMultiSupport {

/**

  • 获取多条目View类型的数量

*/

int getViewTypeCount();

/**

  • 根据数据,获取多条目布局ID

*/

int getLayoutId(T data);

/**

  • 根据数据,获取多条目的ItemViewType

*/

int getItemViewType(T data);

/**

  • 是否合并条目–>>使用RecyclerView时,如果无效,请用原生的RecyclerView

*/

boolean isSpan(T data);

六、打造RecyclerView、ListView、GridView通用的适配器

由于要同时适配RecyclerView、ListView、GridView,也就等于把两个Adapter的实现放在一个类里面

所以代码有点多,但代码我已分开,很容易看。

还有数据都复制出来的,条目的增删改查都在Adapter里面。

/**

  • RecyclerView、ListView、GridView通用的适配器

*/

public abstract class QuickAdapter extends BaseAdapter {

private Context mContext;

private List mData;

private int mLayoutId;

private QuickMultiSupport mSupport;

private boolean isRecycler;

private int mPosition;

public QuickAdapter(Context context, List data, int layoutId) {

this.mContext = context;

this.mData = data == null ? new ArrayList() : new ArrayList(data);

this.mLayoutId = layoutId;

}

public QuickAdapter(Context context, List data, QuickMultiSupport support) {

this(context, data, 0);

this.mSupport = support;

}

@Override

public int getCount() {

return mData.size();

}

@Override

public T getItem(int position) {

return mData.get(position);

}

@Override

public long getItemId(int position) {

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

QuickViewHolder holder;

if (convertView == null) {

int layoutId = mLayoutId;

// 多条目的

if (mSupport != null) {

layoutId = mSupport.getLayoutId(mData.get(position));

}

// 创建ViewHolder

holder = createListHolder(parent, layoutId);

} else {

holder = (QuickViewHolder) convertView.getTag();

// 防止失误,还要判断

if (mSupport != null) {

int layoutId = mSupport.getLayoutId(mData.get(position));

// 如果布局ID不一样,又重新创建

if (layoutId != holder.getLayoutId()) {

// 创建ViewHolder

holder = createListHolder(parent, layoutId);

}

}

}

// 绑定View的数据

convert(holder, mData.get(position), position);

return holder.itemView;

}

/**

  • 创建ListView的Holer

*/

@NonNull

private QuickViewHolder createListHolder(ViewGroup parent, int layoutId) {

QuickViewHolder holder;

View itemView = LayoutInflater.from(mContext).inflate(layoutId, parent, false);

holder = new QuickViewHolder(itemView, layoutId);

itemView.setTag(holder);

return holder;

}

/**

  • ViewType的数量

*/

@Override

public int getViewTypeCount() {

// 多条目的

if (mSupport != null) {

return mSupport.getViewTypeCount() + super.getViewTypeCount();

}

return super.getViewTypeCount();

}

/**

  • 这个方法是共用的

*/

@Override

public int getItemViewType(int position) {

mPosition = position;

// 多条目的

if (mSupport != null) {

return mSupport.getItemViewType(mData.get(position));

}

return super.getItemViewType(position);

}

// RecyclerView=================================================================================

@Override

public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

isRecycler = true;

// 如果是多条目,viewType就是布局ID

View view;

if (mSupport != null) {

int layoutId = mSupport.getLayoutId(mData.get(mPosition));

view = LayoutInflater.from(mContext).inflate(layoutId, parent, false);

} else {

view = LayoutInflater.from(mContext).inflate(mLayoutId, parent, false);

}

QuickViewHolder holder = new QuickViewHolder(view);

return holder;

}

@Override

public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {

if (holder instanceof QuickViewHolder) {

convert((QuickViewHolder) holder, mData.get(position), position);

}

}

@Override

public int getItemCount() {

return mData.size();

}

@Override

public void onAttachedToRecyclerView(RecyclerView recyclerView) {

if (mSupport == null || recyclerView == null) {

return;

}

RecyclerView.LayoutManager layoutManager = recyclerView.getLayoutManager();

if (layoutManager instanceof GridLayoutManager) {

final GridLayoutManager gridLayoutManager = (GridLayoutManager) layoutManager;

final GridLayoutManager.SpanSizeLookup spanSizeLookup = gridLayoutManager.getSpanSizeLookup();

// 如果设置合并单元格就占用SpanCount那个多个位置

gridLayoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {

@Override

public int getSpanSize(int position) {

if (mSupport.isSpan(mData.get(position))) {

return gridLayoutManager.getSpanCount();

} else if (spanSizeLookup != null) {

return spanSizeLookup.getSpanSize(position);

}

return 1;

}

});

gridLayoutManager.setSpanCount(gridLayoutManager.getSpanCount());

}

}

@Override

public void onViewAttachedToWindow(RecyclerView.ViewHolder holder) {

if (mSupport == null) {

return;

}

int position = holder.getLayoutPosition();

// 如果设置合并单元格

if (mSupport.isSpan(mData.get(position))) {

ViewGroup.LayoutParams lp = holder.itemView.getLayoutParams();

if (lp != null && lp instanceof StaggeredGridLayoutManager.LayoutParams) {

StaggeredGridLayoutManager.LayoutParams p = (StaggeredGridLayoutManager.LayoutParams) lp;

p.setFullSpan(true);

}

}

}

// RecyclerView=================================================================================

/**

  • 绑定View的数据

*/

protected abstract void convert(QuickViewHolder holder, T item, int position);

//数据相关======

public void add(T elem) {

mData.add(elem);

notifyData();

}

public void addAll(List data) {

mData.addAll(data);

notifyData();

}

public void addFirst(T elem) {

mData.add(0, elem);

notifyData();

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

总结

开发是面向对象。我们找工作应该更多是面向面试。哪怕进大厂真的只是去宁螺丝,但你要进去得先学会面试的时候造飞机不是么?

作者13年java转Android开发,在小厂待过,也去过华为,OPPO等,去年四月份进了阿里一直到现在。等大厂待过也面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

960页全网最全Android开发笔记

资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
[外链图片转存中…(img-ejEDTnCH-1711741771105)]

总结

开发是面向对象。我们找工作应该更多是面向面试。哪怕进大厂真的只是去宁螺丝,但你要进去得先学会面试的时候造飞机不是么?

作者13年java转Android开发,在小厂待过,也去过华为,OPPO等,去年四月份进了阿里一直到现在。等大厂待过也面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

[外链图片转存中…(img-LJaMR3zP-1711741771105)]

[外链图片转存中…(img-s3xzmnXr-1711741771106)]

资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值