Android正确关闭线程
2016-01-18 12:38
471 查看
Android正确关闭线程
1、正常关闭:推荐使用业务标志位结束线程的工作流程,待线程工作结束自行关闭,如下 mWorking 进行控制线程的业务是否继续进行:/** * start thread running */ public void start() { mWorking = true; if (mThread != null && mThread.isAlive()) { if (DEBUG) { LogHelper.i(TAG, "start: thread is alive"); } } else { mThread = new Thread(new Runnable() { @Override public void run() { int interval = 1000 / FRAMES; while (mWorking) { moveCircularly(); moveToPercent(); postInvalidate(); SystemClock.sleep(interval); } if (DEBUG) { LogHelper.i(TAG, "run: thread stopping"); } } }); mThread.start(); } } /** * stop thread running */ public void stop() { if (mWorking) { mWorking = false; } }
2、暴力型(不推荐):一般不使用这种方法关闭线程,Thread.interrupt() 较暴力,虽然进行
mThread.interrupt(); mThread = null;
终止了线程,但查看源码我们发现:
interrupt() 使线程接受一个终端请求,接下来的线程操作有线程当前状态决定。
线程在 wait(), join() 或 sleep() 状态下,它将被唤醒,并被清除状态,让后会收到一个InterruptedException的
Exception,线程中断 Exception 处理.结束工作。
线程 blocked 在I/ O操作时,会接收ClosedByInterruptException。同样的,该信道将被关闭,线程结束工作。
线程 blocked在Selector 时会立即中断重置状态 return。此情况下,不接收异常。
/**
* start running
*/
public void start() {
mWorking = true;
if (mThread != null && mThread.isAlive()) {
if (DEBUG) {
LogHelper.i(TAG, "start: thread is alive");
}
} else {
mThread = new Thread(new Runnable() {
@Override
public void run() {
int interval = 1000 / FRAMES;
while (mWorking) {
moveCircularly();
moveToPercent();
postInvalidate();
SystemClock.sleep(interval);
}
}
});
mThread.start();
}
}
public void stop() {
if (mWorking) {
if (mThread != null && mThread.isAlive()) {
mThread.interrupt(); mThread = null;
}
mWorking = false;
}
}
其实,项目中会集成个性化的线程池,保证不开启过多的线程进行多线程操作(硬件层CPU 支持的核心数有限,过多的线程只能更加分割 cpu 时间片,无法达到更好的效果),也会有自己的新线程创建、管理和结束操作。
在工作中我们将Android Thread分两种线程进行管理,即 UI Thread (最多 Thread 数由 cpu 核心数决定)和 Bkg Thread (最大Thread数为1).
private ThreadPoolExecutor mUiThreadPoolExecutor; private ThreadPoolExecutor mBkgThreadPoolExecutor;
private int getUiInitialThreadPoolSize() { int cpuCores = Runtime.getRuntime().availableProcessors(); return Math.max(2, cpuCores / 2); // at least 2, or (cores/2) }
分别进行线程池管理
我们只进行 addTask 进行ThreadFactory new adding thread. 而不强行进行 thread 的关闭处理,由线程业务结束自行结束线程。
先写到这里,更多关于线程方面的知识以后可以多多交流。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories