原理:
原理就是用SparseArray,这样也少了创建ViewHolder类,缺点就是判断增加了不止2倍,不过和没有优化复用的来说还是快很多。
方案:
这个写法是看别人的,有兴趣的可以搜下,虽然觉得代码不是很好,但是写法确实很诱人,毕竟ViewHolder的写法确实太臃肿。
public static <T extends View> T getHolderView(View view, int id) {
SparseArray<View> viewHolder = (SparseArray<View>) view.getTag();
if (viewHolder == null) {
viewHolder = new SparseArray<View>();
view.setTag(viewHolder);
}
View childView = viewHolder.get(id);
if (childView == null) {
childView = view.findViewById(id);
viewHolder.put(id, childView);
}
return (T) childView;
}
我是我优化过的,只优化了一处,少了一次判断。
@SuppressWarnings("unchecked")
public static <T extends View> T getHolderView(View view, int id) {
SparseArray<View> viewHolder = (SparseArray<View>) view.getTag();
View childView;
if (viewHolder == null) {
viewHolder = new SparseArray<View>();
view.setTag(viewHolder);
// 先创建的ViewHolder自然没有缓存View所以不用判断
childView = view.findViewById(id);
viewHolder.put(id, childView);
} else {
childView = viewHolder.get(id);
if (childView == null) {
childView = view.findViewById(id);
viewHolder.put(id, childView);
}
}
return (T) childView;
}