所谓线程(Thread) 是指一串接连的履行动作,以达到一项意图。
电脑内部都稀有串接连性的动作一起在进行。也便是有多条线程并行地 (Concurrently)履行。
在电脑中,若电脑具有多颗CPU,则每颗CPU可各照料一个线程,所以可多个线程一起间进行。若只要单一CPU,则此CPU 可一起(Concurrently)照料数个线程。
无论是多CPU或单一CPU的电脑,多条线程并行地履行,都可添加履行功率。
在Android渠道里也不破例,无论是在Java 层或是C++层,都常常见到多条线程并行 的景象。
Android采纳Java的Thread结构,来帮忙树立多条线程并行的环境。
1、知道Android的主线程(又称UI线程)
UI线程的责任:敏捷处理UI作业
在Android里,照顾UI画面的作业(Event) 是UI线程的重要责任,而且是它的专属责任,其它子线程并不能够干预操作UI画面上的目标
因为Android期望UI线程能够给予用户的要求做快速的反响。假如UI线程花费太多时间做暗地的作业,而在UI作业产生之后, 让用户等候超越5秒钟而未处理的话, Android就会向用户抱歉。
当咱们发动某一个APP时,Android就会诞生新进程(Process),而且将该APP程序加载这新诞生的进程里。每个进程在其诞生时间,都会诞生一个主线程,又称为UI线程。
在进程诞生时间,除了诞生主线程之外, 还会替主线程诞生它专用的Message Queue和Main Looper。
这个Main Looper便是让主线程没事时就来履行Looper,保证主线程永久活着而不会死掉;在履行Looper时,会持续调查它的Message Queue是否有新的信息进来; 假如有新信息进来的话,主线程就会赶快去处理(呼应)它。
例如,用户在UI画面上按下一个Button按钮时,UI作业产生了,就会丢一些信息到MQ里,其间包含onClick信息,所以,主线程会及时从MQ里取出onClick信息,然后调用Activity的onClick()函数去处理。处理完毕之后,主线程又返回去持续履行信息循环,持续监督它的MQ,一向循环下去,直到主线程的生命周期的终了。
通常是进程被删去时,主线程才会被删去
Android里有一个Looper类,其目标里含有一个信息循环(Message Loop)。也便是说,一个主线程有它自己专属的Looper目标,此线程诞生时,就会履行此目标里的信息循环。
因为主线程会持续监督MQ的动态,所以在程序的任何函数,只要将信息(以Message类其他目标表明之)丢入主线程的MQ里, 就能与主线程交流了。
在Android里,也界说了一个Handler类, 在程序的任何函数里,能够诞生Handler目标来将Message目标丢入MQ里,而与主线程进行交流。
但是,主线程诞生子线程时,于预设景象下,子线程并不具有自己的Looper目标和 MQ。因为没有Looper目标,就没有信息回圈(Message Loop),一旦作业完毕了, 此子线程就完毕了。
已然没有Looper目标也没有MQ,也就不能承受外来的Message目标了。则其他线程就无法透过MQ来传递信息给它了。
那么,假如其他线程(如主线程)需要与子线程通讯时,该怎么呢? 答案是:替它诞生一 个Looper目标和一个MQ就行了。
2、子线程丢信息给主线程
子线程也能够诞生Handler目标来将 Message目标丢到主线程的MQ里,又能与主线程通讯了
public class ac01 extends Activity implements OnClickListener {
private Thread t;
private Handler h;
private String str;
public void onCreate(Bundle icicle) {
t = new Thread(new Task());
t.start();
}
public void onClick(View v) {
switch (v.getId()) {
case 101:
Message m = h.obtainMessage(1, 33, 1, null);
h.sendMessage(m);
break;
case 102:
setTitle(str);
break;
case 103:
h.getLooper().quit();
finish();
break;
}
}
class Task implements Runnable {
public void run() {
Looper.prepare();
h = new Handler() {
public void handleMessage(Message msg) {
str = Thread.currentThread().getName() + , value= + String.valueOf(msg.arg1);
}
Looper.loop();
} }}
Step-1: 一开始,由主线程履行onCreate() 函数。主线程持续履行到指令:
t = new Thread(new
Task()); t.start();
诞生一个子线程,并发动子线程去履行Task的run()函数,而主线程则返回到信息回圈,并持续监督MQ的动态了
Step-2: 此刻,子线程履行到run()函数里 的指令:
Looper.prepare();
就诞生一个Looper目标,预备好一个信息回圈(Message Loop) 和MQ数据结构。
持续履行到:
h = new Handler(){ //…..
}
就诞生一个Handler目标,可帮忙将信息丢到子线程的MQ上。