A. android主线程和子线程怎么切换的
设置标记变量,while(isValid){} 如果想退出的时候,将isValid置为false
B. 主线程什么都没做,就会等待子线程结束。这是为什么
你这个主线程没有等子线程先执行,主线程几个字不先打出来吗,你可以在主线程里面用 a1.join(); 这样主线程就会等子线程先执行。
C. android 主线程和子线程有什么区别
本文较为深入的分析了android中UI主线程与子线程。分享给大家供大家参考。具体如下:
在一个Android 程序开始运行的时候,会单独启动一个Process。默认的情况下,所有这个程序中的Activity或者Service(Service和 Activity只是Android提供的Components中的两种,除此之外还有Content Provider和Broadcast Receiver)都会跑在这个Process。
一个Android 程序默认情况下也只有一个Process,但一个Process下却可以有许多个Thread。在这么多Thread当中,有一个Thread,我们称之为UI Thread。UI Thread在Android程序运行的时候就被创建,是一个Process当中的主线程Main Thread,主要是负责控制UI界面的显示、更新和控件交互。在Android程序创建之初,一个Process呈现的是单线程模型,所有的任务都在一个线程中运行。因此,我们认为,UI Thread所执行的每一个函数,所花费的时间都应该是越短越好。而其他比较费时的工作(访问网络,下载数据,查询数据库等),都应该交由子线程去执行,以免阻塞主线程。
那么,UI Thread如何和其他Thread一起工作呢?常用方法是:诞生一个主线程的Handler物件,当做Listener去让子线程能将讯息Push到主线程的Message Quene里,以便触发主线程的handlerMessage()函数,让主线程知道子线程的状态,并在主线程更新UI。
例如,在子线程的状态发生变化时,我们需要更新UI。如果在子线程中直接更新UI,通常会抛出下面的异常:
11-07 13:33:04.393: ERROR/JavaBinder(1029):android.view.ViewRoot$:Only the original thread that created a view hierarchy can touch its views.
意思是,无法在子线程中更新UI。为此,我们需要通过Handler物件,通知主线程Ui Thread来更新界面。
如下,首先创建一个Handler,来监听Message的事件:
private final int UPDATE_UI = 1;
private Handler mHandler = new MainHandler();
private class MainHandler extends Handler {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case UPDATE_UI: {
Log.i("TTSDeamon", "UPDATE_UI");
showTextView.setText(editText.getText().toString());
ShowAnimation();
break;
}
default:
break;
}
}
}
或者:
private Handler mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case UPDATE_UI: {
Log.i("TTSDeamon", "UPDATE_UI");
showTextView.setText(editText.getText().toString());
ShowAnimation();
break;
}
default:
break;
}
}
}
当子线程的状态发生变化,则在子线程中发出Message,通知更新UI。
mHandler.sendEmptyMessageDelayed(UPDATE_UI, 0);
在我们的程序中,很多Callback方法有时候并不是运行在主线程当中的,所以如果在Callback方法中更新UI失败,也可以采用上面的方法。
D. Android可以让主线程在其他子线程执行完后再执行吗如果可以,该怎么做
android中什么时候会选择用广播来进行线程间的通信 Android 多线程 通信 线程中通信就不要用广播了吧 进程中通信可以用广播或者aidl 可是,这两天看到的项目都是这么做的;然后,自己分析了下,觉得一下的理由也是可以成立的; 1.正常情况下我们选择handler消息机制来进行单向的线程间的通信;(工作线程向主线程发送消息) 因为主线程有现成的handler,而工作线程没有现成的handler,这样的话,主线程将handler交给工作线程而让工作线程将工作的结果交给主线程; 相反,工作线程中没有现成的handler(事实上是没有消息队列,也就是handler没有绑定到工作线程),那么,如果开辟的话,代码角度上是挺麻烦的(相对应广播机制来说); 2.广播机制本身就是双向的(工作线程向主线程发送广播,主线程向工作线程发送广播); //另外,对于像一个activity中通过fragment来进行界面的处理; 我们大多数情况下是采用广播的机制来实现fragment中adapter的数据的更新;这样做主要是考虑到工作线程的任务加载完成,而具体的对应刷新的activity可能还没有启动; 另外,基于接口隔离原则,如果用handler进行通信的话,则不能很好的满足这一原则; 你要是周期比较长 用广播好些吧 应该与周期关系不是很密切。最主要的原因是两条线成是双向通信。 Handler类似于P2P的通信。 广播则类似于一个server端,用来处理分发不同线程的请求,从控制器的角度来说用广播更好一点。 一般使用Handler的,多用于子线程处理事务,完成时告知主线程这一类的情况。 而类似楼主所说的多条线程之间需要频繁交互的话,广播是个很好的选择,并且结构清晰,只是不知道广播的性能与handler相比会怎么样。
E. android中主线程执行时,子线程执行吗
执行,但一般不与视图交互,因为在android 中还有一个headler概念,我对这块也不是特别清楚
F. 关于主线程等待子线程结束的问题。
如果非要这么做的话,我能想到的是增加状态变量,在子线程处理完后更改状态变量的值,在主线程中使用循环检查状态变量的值,检测到子处理完后跳出循环,继续主线程。
G. android怎么让主线程等待子线程的执行
http://blog.csdn.net/null1989/article/details/11972881
H. 如何使“主线程”等待“子线程”执行结束后再继续执行
在主线程里调用子线程,这样“子线程”执行结束后,才会继续执行主线程的后续程序。