亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android Thread 介紹與實(shí)例

 更新時(shí)間:2013年06月03日 10:30:22   作者:  
Android Thread 介紹與實(shí)例,需要的朋友可以參考一下

Android中很重要的一個(gè)機(jī)制就是線程+消息,當(dāng)然線程并不是android獨(dú)有的,下面,簡(jiǎn)單的說說使用線程的時(shí)候應(yīng)該注意的地方

我們采用最簡(jiǎn)單的方法來建立一個(gè)android的線程+消息的例子

1.Thread + Handler

[java]

復(fù)制代碼 代碼如下:

package com.example.test_thread;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.TextView;

public class MainActivity extends Activity {

    TextView mTextView = null;
//  static TextView mTextView = null; 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView)findViewById(R.id.textview);
        Thread th = new Thread(new Runnable() {

            @Override
            public void run() {
                // TODO Auto-generated method stub 
                for(int i = 0;i<1000;i++)
                {
                    try {
                        Thread.sleep(500);
                        System.out.println("Thread running :"+i+"!");
                        Message msg = new Message();
                        msg.what = i;
                        mHandler.sendMessage(msg);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block 
                        e.printStackTrace();
                    }
                }
            }
        });
        th.start();

    }
    public Handler mHandler = new Handler(){
//    public static Handler mHandler = new Handler(){ 

        @Override
        public void handleMessage(Message msg) {
            // TODO Auto-generated method stub 
            super.handleMessage(msg);

            mTextView.setText(String.valueOf(msg.what));
        }

    };

}

package com.example.test_thread;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.TextView;

public class MainActivity extends Activity {

 TextView mTextView = null;
// static TextView mTextView = null;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView)findViewById(R.id.textview);
        Thread th = new Thread(new Runnable() {

   @Override
   public void run() {
    // TODO Auto-generated method stub
    for(int i = 0;i<1000;i++)
    {
     try {
      Thread.sleep(500);
      System.out.println("Thread running :"+i+"!");
      Message msg = new Message();
      msg.what = i;
      mHandler.sendMessage(msg);
     } catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
     }
    }
   }
  });
        th.start();

    }
    public Handler mHandler = new Handler(){
//    public static Handler mHandler = new Handler(){

  @Override
  public void handleMessage(Message msg) {
   // TODO Auto-generated method stub
   super.handleMessage(msg);

   mTextView.setText(String.valueOf(msg.what));
  }

    };

}

當(dāng)我們用以上方式建立線程時(shí),進(jìn)入應(yīng)用之后,線程開始運(yùn)行,Handler接收消息改變UI中的TextView,此時(shí)一切正常

當(dāng)按下退出時(shí),程序退出,但是程序進(jìn)程還在stack中,因此主線程之子線程,也就是我們定義的th(th_1)不會(huì)退出,此時(shí),在log信息中可以看到,system.out還在print數(shù)字

當(dāng)再次進(jìn)入程序的時(shí)候,可以看到,log中打印的信息double,但是UI會(huì)按照新線程(th_2)的次序改變

此時(shí)th_1仍在運(yùn)行,th_1使用的 handler_1也在運(yùn)行,只不過上一個(gè)Activity的狀態(tài)已經(jīng)是finish,因此不會(huì)改變UI  this ->mFinished= true

其實(shí)只要th_1中有關(guān)于上一個(gè)Activity的引用,那么Activity就不會(huì)銷毀,java的機(jī)制就是這樣,這是我們推薦的線程機(jī)制,下面著重說一下可能遇到的問題

2.同樣是剛剛的例子,我們將Handler定義成static

[java]
public static Handler mHandler = new Handler(){

public static Handler mHandler = new Handler(){此時(shí),在退出應(yīng)用再重新進(jìn)入時(shí),由于Handler并不會(huì)有新的實(shí)例,因此,th_1與th_2同時(shí)發(fā)消息給一個(gè)static Handler 或者說是指向了同一塊內(nèi)存區(qū)域,這時(shí)就會(huì)出現(xiàn)TextView上的數(shù)字來回跳的現(xiàn)象

3.這樣也可以

使用static定義Handler也不是不可以,只要在Activity的onCreate()中重新實(shí)例一個(gè)Handler,這樣,JVM分配另一塊內(nèi)存給新的Handler,這樣運(yùn)行就正常了

[java]

復(fù)制代碼 代碼如下:

package com.example.test_thread;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.TextView;

public class MainActivity extends Activity {

    public Handler mHandler = null;
    TextView mTextView = null;
//  static TextView mTextView = null; 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView)findViewById(R.id.textview);
        mHandler = new TestHandler();
        Thread th = new Thread(new Runnable() {

            @Override
            public void run() {
                // TODO Auto-generated method stub 
                for(int i = 0;i<1000;i++)
                {
                    try {
                        Thread.sleep(500);
                        System.out.println("Thread running :"+i+"!");
                        Message msg = new Message();
                        msg.what = i;
                        mHandler.sendMessage(msg);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block 
                        e.printStackTrace();
                    }
                }
            }
        });
        th.start();

    }
    class TestHandler extends Handler
    {
        @Override
        public void handleMessage(Message msg) {
            // TODO Auto-generated method stub 
            super.handleMessage(msg);
            System.out.println("Handler running :"+msg.what+"!");
            mTextView.setText(String.valueOf(msg.what));
        }

    }
}

package com.example.test_thread;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.TextView;

public class MainActivity extends Activity {

    public Handler mHandler = null;
 TextView mTextView = null;
// static TextView mTextView = null;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = (TextView)findViewById(R.id.textview);
        mHandler = new TestHandler();
        Thread th = new Thread(new Runnable() {

   @Override
   public void run() {
    // TODO Auto-generated method stub
    for(int i = 0;i<1000;i++)
    {
     try {
      Thread.sleep(500);
      System.out.println("Thread running :"+i+"!");
      Message msg = new Message();
      msg.what = i;
      mHandler.sendMessage(msg);
     } catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
     }
    }
   }
  });
        th.start();

    }
    class TestHandler extends Handler
    {
  @Override
  public void handleMessage(Message msg) {
   // TODO Auto-generated method stub
   super.handleMessage(msg);
   System.out.println("Handler running :"+msg.what+"!");
   mTextView.setText(String.valueOf(msg.what));
  }

    }
}


當(dāng)然,總的來說Java還是不推薦使用static變量的,這本身也不符合面向?qū)ο蟮淖兂伤枷?,所以,建議除了一些final值,盡量還是多使用消息機(jī)制來解決問題,維護(hù)也輕松些

相關(guān)文章

最新評(píng)論