Loader載入器

来源:http://www.cnblogs.com/volcano-c/archive/2016/11/14/6063101.html
-Advertisement-
Play Games

今天學到了這個Loader,淺談一下自己的看法: 1.定義 Loader是一個載入器,可以用來它訪問數據,可以看做訪問數據的機器(好比挖掘機)。裝再器從android3.0開始引進,它使得在activity或fragment中非同步載入數據變得簡單。 具有如下特別: 1)它們對每個Activity和F ...


今天學到了這個Loader,淺談一下自己的看法:

1.定義

Loader是一個載入器,可以用來它訪問數據,可以看做訪問數據的機器(好比挖掘機)。裝再器從android3.0開始引進,它使得在activity或fragment中非同步載入數據變得簡單。

具有如下特別:

1)它們對每個Activity和Fragment都有效

2)它們提供了非同步載入數據的能力

3)它擁有一個數據改變通知機制,當數據源做出改變是會及時通知。當Cursor發生變化時,會自動載入數據,因此不需要重新進行數據查詢

解釋一下為什麼會有非同步載入數據的能力:

final class LoadTask extends ModernAsyncTask<Void, Void, D> implements Runnable {
private final CountDownLatch mDone = new CountDownLatch(1);

// Set to true to indicate that the task has been posted to a handler for
// execution at a later time. Used to throttle updates.
boolean waiting;

/* Runs on a worker thread */
@Override
protected D doInBackground(Void... params) {
if (DEBUG) Log.v(TAG, this + " >>> doInBackground");
try {
D data = AsyncTaskLoader.this.onLoadInBackground();
if (DEBUG) Log.v(TAG, this + " <<< doInBackground");
return data;
} catch (OperationCanceledException ex) {
if (!isCancelled()) {
// onLoadInBackground threw a canceled exception spuriously.
// This is problematic because it means that the LoaderManager did not
// cancel the Loader itself and still expects to receive a result.
// Additionally, the Loader's own state will not have been updated to
// reflect the fact that the task was being canceled.
// So we treat this case as an unhandled exception.
throw ex;
}
if (DEBUG) Log.v(TAG, this + " <<< doInBackground (was canceled)", ex);
return null;
}
}
protected D onLoadInBackground() {
return loadInBackground();
}
public abstract D loadInBackground();
這是AsyncTaskLoader底層代碼實現。可以看出,在AsyncTaskLoader中創建一個final修飾的內部類,實現非同步任務。封裝了一個抽象方法loadInBackground(),在子類繼承時,實現各自的實現方式。

2.作用

用來載入數據,訪問資料庫(系統自帶的資料庫,自定義資料庫)。當然訪問資料庫,我們可以使用ContentResolver通過query()訪問資料庫,得到一個Cursor對象,遍歷這個對象就可以拿到我們想要的數據。但Loader的作用比ContentResolver更簡便更快捷。

3.用法(使用裝載器時設計到的類和方法)

LoaderManager:本身是一個抽象類。關聯到每一個Activity或Fragment,管理一個或多個裝載器的實例。這幫助一個應用管理那些與Activity或Fragment的聲明周期相關的長時間運行的操作。最常見的方式是與一個CursorLoader一起使用,然而應用是可以隨便寫它們自己的載入器從而載入其他類型的數據。

LoaderManager.LoaderCallBack<D>:本身是一個介面。一個用於客戶端與LoaderManager交互的回調介面。如:你可以使用onCreateLoader()創建一個Loader載入器

Loader:本身是一個抽象類。一個執行非同步數據載入的抽象類。它是載入器的基類,你可以使用典型的CursorLoader,但是你也可以使用自定義的Loader(創建一個類extends AsyncTaskLoader),它們將監試它們的數據源並且在數據改變是發送新的結果。

AsyncTaskLoader:本身是一個抽象類,提供一個AsyncTask來執行非同步載入工作(工作在子線程,進行耗時操作)。

CursorLoader:AsyncTaskLoader的實現類。

4.我自己寫的一個demo訪問手機聯繫人

package com.yz.searchcontacts;

import android.content.ContentResolver;
import android.content.Context;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.support.v4.app.LoaderManager;
import android.support.v4.content.AsyncTaskLoader;
import android.support.v4.content.Loader;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.SearchView;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;

public class MainActivity extends AppCompatActivity implements LoaderManager.LoaderCallbacks<Cursor> {

private ListView lv_contacts;
private SearchView msv_name;
private static ContentResolver mResolver;
private SimpleCursorAdapter mAdapter;
private LoaderManager manager;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//獲取控制項
msv_name = (SearchView) findViewById(R.id.sv_name);
lv_contacts = (ListView) findViewById(R.id.list_item);
//創建適配器
mAdapter = new SimpleCursorAdapter(this, R.layout.list_item,null,new String[]{"_id","display_name"},new int[]{R.id.tv_id,R.id.tv_name},SimpleCursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER);
lv_contacts.setAdapter(mAdapter);
//創建loader載入器,並初始化
manager = getSupportLoaderManager();
manager.initLoader(1,null,this);
//獲取ContentResolver
mResolver = getContentResolver();
}


@Override
public Loader<Cursor> onCreateLoader(int id, Bundle args) {

return new MyLoader(this,args);
}

@Override
public void onLoadFinished(Loader<Cursor> loader, Cursor data) {

mAdapter.swapCursor(data);
//為SearchView設置監聽
msv_name.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
return false;
}

@Override
public boolean onQueryTextChange(String newText) {
Bundle args = new Bundle();
args.putString("name",newText);
manager.restartLoader(1,args,MainActivity.this);
return true;
}
});
}

@Override
public void onLoaderReset(Loader<Cursor> loader) {
mAdapter.swapCursor(null);
}
//自定義Loader
static class MyLoader extends AsyncTaskLoader<Cursor>
{
private Bundle args;
public MyLoader(Context context,Bundle args) {
super(context);
this.args = args;
}

@Override
protected void onStartLoading() {
super.onStartLoading();
//強制載入
forceLoad();
}

@Override
public Cursor loadInBackground() {
//進行耗時操作
Uri uri = ContactsContract.RawContacts.CONTENT_URI;
if (args != null) {

Cursor cursor = mResolver.query(uri, new String[]{"_id", "display_name"}, "display_name like ?", new String[]{"%" + args.getString("name") + "%"}, null);
return cursor;
}else
{
Cursor cursor = mResolver.query(uri, new String[]{"_id", "display_name"}, null, null, null);
return cursor;
}
}
}
}在這個簡單的小程式里有幾個我犯的小問題,提醒一下:
1)包的一致性
2)
 protected void onStartLoading() {
super.onStartLoading();
//強制載入
forceLoad();
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近兩天在做一個簡單的聊天室程式,涉及到了jquery的Ajax的無刷新更新頁面、php連接mysql資料庫、mysql的簡單操作以及mysql和mysqli的區別。 我是在APPServ的Web環境下做的,使用這個環境的好處是所有建立web網頁的組件都已經集成進去了,這樣就可以忽略構建網頁的其他組 ...
  • 本地預覽圖片html和js例子,直接上代碼吧。 <!--WizRtf2Html Charset=0 --><!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type ...
  • 1、前端基礎 盒子模型 位置(相對 絕對) 瀏覽器渲染順序(從上而下,從外到里;如果裡面有寬度則再從里而在,如div沒有設置寬度則一直撐大到設置了寬度的div為止) 浮動 2、基礎佈局 中間固定兩邊自適應(就是居中了) 可用display:inline-block 和text-align:cente ...
  • 在CSS3中提供了對邊框進行圓角設定的支持,可對邊框1~4個角進行圓角樣式設置。 ...
  • 1、SVG繪圖總結: ①方法一:已有svg文件,<img src="x.svg"> 方法二:<body><svg></svg></body> ②繪製矩形:<rect x="" y="" width="" height=""></rect> ③繪製圓形:<circle cx="" cy="" r="" ...
  • jquery美化選擇器實例有:邊框、下劃線、 伸縮 、滑動、 覆蓋、 旋轉、 彈出層選擇 、環形效果。 線上預覽 實例代碼 <body class="demo-1"> <div class="container"> <header class="codrops-header"> <h1> 自定義選擇 ...
  • //創建新的tcp伺服器var net = require('net');var chatServer = net.createServer()chatServer.on('connection',function(client){ client.write('Hi\n'); client.writ ...
  • 先上效果圖: 獲取手機已安裝的App列表利用Android系統API就可以辦到,這裡為什麼要引入RxJava?現在我們假設一下有下麵幾個需求: 1、我們不需要所有的App,只需要用戶安裝的第三方App,即過濾到系統App; 2、我們自定義一個AppInfo類,該類中保存了App_Icon、App_N ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...