• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            life02

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              197 隨筆 :: 3 文章 :: 37 評論 :: 0 Trackbacks
            http://blog.csdn.net/poechant/article/details/7371461

            Android 開發之道(10)Handler本質簡析與使用實例

            • 作者:柳大·Poechant
            • 郵箱:zhongchao.ustc@gmail.com
            • 博客:blog.csnd.net/poechang
            • 日期:March 19th, 2012

            1 Overview

            先淺析本質太過抽象,還是先上 Handler 的最簡實例吧。

            • 功能:Android.os.Handler負責接收,并按計劃發送和處理消息;
            • 特點:處理消息是阻塞式的;
            • 本質:關于Handler的內部機制,及其與Looper的關系,請看本文的第三部分“消息處理機制的本質”。

            2 Get Started

            2.1 先創建一個 Handler 對象,

            private Handler mHandler = new Handler();

            但這樣的Handler是沒用的。不過先暫且不要管,往下面看。

            2.2 向 Handler 的消息隊列發送數據

            發送數據的動作是通過 sendMessage 完成的。

            Message message = new Message();  
            message.what = 1;

            // 將消息發送到mHandler的消息隊列的最后
            mHandler.sendMessage(message);

            不過實際上,在 Handler 內部有一個 Looper 類,而消息隊列其實是 Looper 的一個成員。Handler 中的 mQueue 就是其成員 mLooper 的 mQueue。

            2.3 處理消息隊列中的數據

            Handler 可以根據 Message 中的 what 值的不同來分發處理,Handler 中提供了 handleMessage 來讓開發人員進行 Override。示例如下:

            public void handleMessage(Message msg) {
            switch (msg.what) {
            case 1:
            // 所做的操作
            break;
            case 2:
            // 所做的操作
            break;
            default:
            // 所做的操作
            }
            };

            完整的寫法,就是在創建 Handler 對象時如下:

            private Handler mHandler = new Handler() {
            public void handleMessage(Message msg) {
            switch (msg.what) {
            case 1:
            // 所做的操作
            break;
            case 2:
            // 所做的操作
            break;
            default:
            // 所做的操作
            }
            };
            }

            2 計時器簡例

            2.1 先創建一個任務類

            Timer 和 TimerTask 是 Java 語言中的類,如果不熟悉,請看下面的例子及注視。

            // 任務類
            private class MyTask extends TimerTask{
            @Override
            public void run() {
            // 創建要發送的消息
            Message message = new Message();
            message.what = 1;

            // 將消息發送到mHandler的消息隊列的最后
            mHandler.sendMessage(message);
            }
            }

            使用方法很簡單,就是用 Timer 來作為容器:

            // 創建用于執行任務類的Timer
            Timer timer = new Timer();

            // 1毫秒之后開始每隔5秒鐘執行一次MyTast
            timer.scheduleAtFixedRate(new MyTask(), 1, 1000);

            2.2 完整的例子

            布局文件就省略了,源碼如下:

            package com.sinosuperman.android;

            import java.util.Timer;
            import java.util.TimerTask;
            import android.app.Activity;
            import android.os.Bundle;
            import android.os.Handler;
            import android.os.Message;
            public class Test extends Activity {

            //title為setTitle方法提供變量,這里為了方便我設置成了int型
            private int mSecs = 0;

            private Handler mHandler = new Handler(){
            // 根據mHandler的消息隊列中的不同消息進行處理
            public void handleMessage(Message msg) {
            switch (msg.what) {
            case 1:
            // 所做的操作
            updateTitle();
            break;
            }
            };
            };

            public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);

            // 創建用于執行任務類的Timer
            Timer timer = new Timer();

            // 1毫秒之后開始每隔5秒鐘執行一次MyTast
            timer.scheduleAtFixedRate(new MyTask(), 1, 1000);
            }

            // 任務類
            private class MyTask extends TimerTask{
            @Override
            public void run() {

            // 創建要發送的消息
            Message message = new Message();
            message.what = 1;

            // 將消息發送到mHandler的消息隊列的最后
            mHandler.sendMessage(message);
            }
            }

            // 處理消息所做的操作
            public void updateTitle(){
            setTitle("Michael's Timer: " + mSecs);
            mSecs++;
            }
            }

            3 消息處理機制的本質

            3.1 Looper 與 Handler 的內部機制

            Looper 中有一個 MessageQueue 的成員,Looper 中還有有一個 loop 函數用來對消息隊列進行循環。Looper 并不直接與 Handler 綁定,我們可以直接“玩弄” Looper,不過 Handler 讓我們“玩弄”她更容易一些。

            Handler 本質上是一個工具類,其內部有 Looper 成員。我們通過 Handler 類完成消息的發送和處理、制定分發機制等等。

            3.2 消息處理機制的本質

            Handler 中封裝了 Looper 成員,Handler 中的消息隊列就是 Looper 中的消息隊列成員。Looper 中有消息的循環分發機制。下面介紹下內部的大致流程:

            1. 當將一個消息通過 sendMessage 交給 Handler 的時候,就是交給了 Looper;
            2. Looper 將消息發送到這個消息指定的 target,而這個“指定”的動作是在 Handler 內部完成的,就是指定為 Handler 自己。
            3. Looper 將這個消息發送給 target 的 dispatchMessage 函數處理,因為 Handler 指定了 target 是自己,所以就是 Handler 的dispatchMessage 函數。
            4. dispatchMessage 函數對該消息進行處理的時候,調用的是 handleMessage,就是由我們自己 override 的那個函數。

            Reference

            1. http://weizhulin.blog.51cto.com/1556324/323922
            2. http://blog.csdn.net/Innost/article/details/6055793

            -

            轉載請注明來自“柳大·Poechant的CSDN博客”:blog.CSDN.net/Poechant

            posted on 2012-03-20 14:04 life02 閱讀(368) 評論(0)  編輯 收藏 引用 所屬分類: android組件學習
            麻豆成人久久精品二区三区免费| 热久久国产欧美一区二区精品| 国产精品美女久久福利网站| 99久久做夜夜爱天天做精品| 亚洲国产另类久久久精品| 久久无码人妻一区二区三区午夜| 少妇久久久久久久久久| 久久精品视频网| 国内精品久久久久影院老司| 久久香蕉超碰97国产精品| 久久91这里精品国产2020| 久久香综合精品久久伊人| 精品国产一区二区三区久久| 久久久高清免费视频| 国内精品久久久久| 精品多毛少妇人妻AV免费久久| 国内精品久久久久| 99久久精品免费看国产一区二区三区| 国产精品久久久久久一区二区三区| 久久伊人亚洲AV无码网站| 久久99精品久久只有精品| 色综合久久夜色精品国产| 久久福利青草精品资源站免费| 久久这里的只有是精品23| 亚洲国产精久久久久久久| 久久99精品久久久久久久久久| 一级做a爰片久久毛片毛片| segui久久国产精品| 精品久久久久久中文字幕| 色狠狠久久AV五月综合| 2021国产精品久久精品| 欧美一区二区久久精品| 亚洲欧美日韩久久精品| 日日狠狠久久偷偷色综合免费| 超级碰久久免费公开视频| 久久国产精品久久国产精品| 99久久久精品| 99热热久久这里只有精品68| 麻豆精品久久久一区二区| 久久天堂电影网| 久久人人爽人人精品视频|