# notifyDataSetChanged 不生效原因
1、在子線程調用
2、數據源引用對象發生變更
# ListView中的Adapter
ListView中的Adapter示例如下:
```java
public class StudentAdaper extends ArrayAdapter<Student> {
public StudentAdaper(Context context, int resourceId, List<Student> studentList) {
super(context, resourceId, studentList);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {}
@Override
public int getItemViewType(int position) {}
@Override
public int getViewTypeCount() {}
static class ViewHolder {}
}
```
其中getView()方法會在item顯示在屏幕上時進行調用。比如共100個item要顯示,但屏幕高度只可以展示10個item,一開始getView()方法會調用10次,滑動界面時,每當有item展示時,再調用相應的getView()方法。
## ListView的優化
### Adapter優化
Layout的inflate()方法和findViewById()方法都是消耗資源的工作,在ListView快速滑動時,會消耗大量資源。所以引入ConvertView和ViewHolder來對布局和View進行緩存。
```java
@Override
public View getView(int position, View convertView, ViewGroup parent) {
Student student = getItem(position);
View view;
ViewHolder viewHolder;
if (convertView == null) {
view = LayoutInflater.from(mContext).inflate(mResourceId, parent, false);
viewHolder = new ViewHolder();
viewHolder.name = view.findViewById(R.id.tv_name);
viewholder.mark = view.findViewById(R.id.tv_mark);
view.setTag(viewHolder);
} else {
view = convertView;
viewHolder = (ViewHolder)view.getTag();
}
viewHolder.name.setText(student.getName());
viewHolder.mark.setText(student.getMark());
return view;
}
```
# RecyclerView中的Adapter
RecyclerView中的Adapter示例如下:
```java
public class StudentAdaper extends RecyclerView.Adapter<StudentAdapter.ViewHolder> {
public StudentAdapter() {}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {}
@Override
public int getItemCount() {}
@Override
public int getItemViewType() {}
static class ViewHolder {}
}
```
其中,屏幕高度只可以展示10個item時,會調用10次onCreateViewHolder,來創建ViewHolder,上下滑動時ViewHolder可以緩存。當item出現(或將要出現在屏幕)時會調用onBindViewHolder,對ViewHolder進行填充。
## RecyclerView的解耦性
* RecyclerView負責View的回收與復用
* LayoutManager負責View的布局管理
* ItemAnimator負責添加刪減動畫展示
* ItemDecoration負責分割線顯示
- 導讀
- Java知識
- Java基本程序設計結構
- 【基礎知識】Java基礎
- 【源碼分析】Okio
- 【源碼分析】深入理解i++和++i
- 【專題分析】JVM與GC
- 【面試清單】Java基本程序設計結構
- 對象與類
- 【基礎知識】對象與類
- 【專題分析】Java類加載過程
- 【面試清單】對象與類
- 泛型
- 【基礎知識】泛型
- 【面試清單】泛型
- 集合
- 【基礎知識】集合
- 【源碼分析】SparseArray
- 【面試清單】集合
- 多線程
- 【基礎知識】多線程
- 【源碼分析】ThreadPoolExecutor源碼分析
- 【專題分析】volatile關鍵字
- 【面試清單】多線程
- Java新特性
- 【專題分析】Lambda表達式
- 【專題分析】注解
- 【面試清單】Java新特性
- Effective Java筆記
- Android知識
- Activity
- 【基礎知識】Activity
- 【專題分析】運行時權限
- 【專題分析】使用Intent打開三方應用
- 【源碼分析】Activity的工作過程
- 【面試清單】Activity
- 架構組件
- 【專題分析】MVC、MVP與MVVM
- 【專題分析】數據綁定
- 【面試清單】架構組件
- 界面
- 【專題分析】自定義View
- 【專題分析】ImageView的ScaleType屬性
- 【專題分析】ConstraintLayout 使用
- 【專題分析】搞懂點九圖
- 【專題分析】Adapter
- 【源碼分析】LayoutInflater
- 【源碼分析】ViewStub
- 【源碼分析】View三大流程
- 【源碼分析】觸摸事件分發機制
- 【源碼分析】按鍵事件分發機制
- 【源碼分析】Android窗口機制
- 【面試清單】界面
- 動畫和過渡
- 【基礎知識】動畫和過渡
- 【面試清單】動畫和過渡
- 圖片和圖形
- 【專題分析】圖片加載
- 【面試清單】圖片和圖形
- 后臺任務
- 應用數據和文件
- 基于網絡的內容
- 多線程與多進程
- 【基礎知識】多線程與多進程
- 【源碼分析】Handler
- 【源碼分析】AsyncTask
- 【專題分析】Service
- 【源碼分析】Parcelable
- 【專題分析】Binder
- 【源碼分析】Messenger
- 【面試清單】多線程與多進程
- 應用優化
- 【專題分析】布局優化
- 【專題分析】繪制優化
- 【專題分析】內存優化
- 【專題分析】啟動優化
- 【專題分析】電池優化
- 【專題分析】包大小優化
- 【面試清單】應用優化
- Android新特性
- 【專題分析】狀態欄、ActionBar和導航欄
- 【專題分析】應用圖標、通知欄適配
- 【專題分析】Android新版本重要變更
- 【專題分析】唯一標識符的最佳做法
- 開源庫源碼分析
- 【源碼分析】BaseRecyclerViewAdapterHelper
- 【源碼分析】ButterKnife
- 【源碼分析】Dagger2
- 【源碼分析】EventBus3(一)
- 【源碼分析】EventBus3(二)
- 【源碼分析】Glide
- 【源碼分析】OkHttp
- 【源碼分析】Retrofit
- 其他知識
- Flutter
- 原生開發與跨平臺開發
- 整體歸納
- 狀態及狀態管理
- 零碎知識點
- 添加Flutter到現有應用
- Git知識
- Git命令
- .gitignore文件
- 設計模式
- 創建型模式
- 結構型模式
- 行為型模式
- RxJava
- 基礎
- Linux知識
- 環境變量
- Linux命令
- ADB命令
- 算法
- 常見數據結構及實現
- 數組
- 排序算法
- 鏈表
- 二叉樹
- 棧和隊列
- 算法時間復雜度
- 常見算法思想
- 其他技術
- 正則表達式
- 編碼格式
- HTTP與HTTPS
- 【面試清單】其他知識
- 開發歸納
- Android零碎問題
- 其他零碎問題
- 開發思路