標籤:
安卓中一個程式跑起來叫進程,進程中至少有一個主線程。主線程用於處理使用者的觸摸操作和將觸摸操作事件分發給響應的控制項。如果進行消耗時間操作,下載,磁碟讀取檔案,不潤許在主線程操作,只能在背景工作執行緒操作。主線程向背景工作執行緒發送訊息和資料,背景工作執行緒也會時時反饋給主線程。線程通訊:多個線程互相收發訊息和資料。安卓規定只有主線程才能修改UI介面和控制項(除了進度條可以在背景工作執行緒修改),如果背景工作執行緒想修改UI介面則只能通知主線程進行修改。Handler:控制代碼,手柄,遙控器,操作板。
mainActivity:
package com.sxt.day06_01;import android.app.Activity;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.os.SystemClock;import android.view.Menu;import android.view.View;import android.view.View.OnClickListener;import android.widget.ProgressBar;import android.widget.TextView;import android.widget.Toast;public class MainActivity extends Activity { Handler mHandler; private static final int DOWNLOADING=1;//下載中,內部類中使用所以用靜態類型, private static final int DOWNLOAD_FINISH=10;//下載完成 ProgressBar mProgressBar; TextView mtvProgress; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); setListener(); initHandler(); } private void initHandler() { //主線程處理訊息 mHandler=new Handler(){ @Override public void handleMessage(Message msg) { switch (msg.what) { case DOWNLOADING: mtvProgress.setText(msg.arg1+"%"); break; case DOWNLOAD_FINISH: Toast.makeText(MainActivity.this, "下載完成", 2000).show(); break; } } }; } private void setListener() { findViewById(R.id.btnStartDownload).setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { new Thread(){//建立線程(背景工作執行緒) public void run() { for(int i=1;i<=100;i++){ SystemClock.sleep(20); mProgressBar.setProgress(i);//這個控制項可以在背景工作執行緒修改 //沒改變一次發送一個訊息,發送100次,發送到Message的隊列中, Message msg=Message.obtain();//靜態方法擷取message,從線程池中取一個對象,線程池是記憶體的一個緩衝區域,如果第一次沒有Message對象會new一個,使用完以後不會銷毀,下次直接從池子中取,線程池最多放10個, msg.what=DOWNLOADING;//what屬性是訊息的類型,整型。 msg.arg1=i;//arg1,arg2也是整型,還有一個obj屬性是Object類型。 mHandler.sendMessage(msg);//發送訊息給主線程,顯示百分比 } //迴圈完以後發送一個結束的訊息 Message msg=Message.obtain(); msg.what=DOWNLOAD_FINISH; mHandler.sendMessage(msg); }; }.start(); } }); } private void initView() { mProgressBar=(ProgressBar) findViewById(R.id.pb); mtvProgress=(TextView) findViewById(R.id.tvProgress); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; }}
頁面:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <Button android:id="@+id/btnStartDownload" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="開始下載" /> <ProgressBar 進度條 android:id="@+id/pb" android:layout_width="match_parent" android:layout_height="wrap_content" style="@android:style/Widget.ProgressBar.Horizontal" android:max="100"/> <TextView 百分比的數字 android:id="@+id/tvProgress" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="20sp" android:text="0%"/></LinearLayout>
android 36 線程通訊