AndroID 开发中线程的分析
今天早上把公司给的任务做完了之后,突然就有点无聊,于是,把以前学的那些东西翻了翻,博客看了看,就看到一个关于线程的博客,有了很大的争议,我也差点误解了(感觉高大上~~~)。整体代码差不多是这样:
package sw.angel.thread; import androID.app.Activity; import androID.os.Bundle; import androID.os.Handler; import androID.util.Log; public class ThreadDemo extends Activity { private static final String TAG = "ThreadDemo"; private int count = 0; private Handler mHandler = new Handler(); private Runnable mRunnable = new Runnable() { public voID run() { //为了方便 查看,我们用Log打印出来 Log.e(TAG,Thread.currentThread().getname() + " " +count); count++; setTitle("" +count); //每2秒执行一次 mHandler.postDelayed(mRunnable,2000); } }; @OverrIDe public voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.main); //通过Handler启动线程 mHandler.post(mRunnable); } protected voID onDestroy() { //将线程销毁掉 //mHandler.removeCallbacks(mRunnable); super.onDestroy(); } }
所谓的争议是什么呢?看了这块代码的大概意思,很多人会以为每2s新开一个线程执行,但程序退出时,线程依旧是执行的。博主就在onDestroy()中加上了removeCallbacks()。大概意思就是移除线程(销毁)。
当然,首先指出的一点就是,这个demo是每2秒执行一次Runable。相当于每2秒执行一次主线程,用logcat打印出来。而不是每2秒新开一个线程。而无论你是否加上最后一句话,你会发现线程没有停止过。相当于,隔2秒就执行一次,无限循环下去。
为什么还会执行?嗯,这是个问题。好了,我也不卖关子了。
退出的时候,程序相当于只是 finish 掉了,如果只是简单的finish的话,该程序并没有销毁掉,主线程还继续运行的,只是被前一个activity覆盖而已。
有人说:AndroID应用本身就是一个进程,当我们退出应用时,这个进程就已经销毁了吧?
可是并没有…
AndroID的特色: 当应用程序退出的时候进程资源并没有销毁,这样做是为了下次启动这个程序的更快…我想AndroID的思想是达到资源利用率的最大化,但这也有弊端,如果有应用需要系统资源,而系统资源又不够,那么就得去销毁掉其它资源,腾出地方来…
如果你想知道是不是真的没有销毁,你可以在onCreate判断savedInstanceState是否等于NulL就可以知道是不是reinitialized了,或者在onBackpressed调用System.exit(0)真正退出进程。
androID的特色之一:并不由用户来销毁activity,activity 的生命周期完全交给系统来管理 ,等系统在适当的时候来回收资源。当你按下backspace键的时候,只是简单的将位于堆栈里下一个activityd出,将原来的activity压栈而已,系统并保存原来的activity的一些历史信息,并不销毁,等你下次打开的时候,能够很快的恢复。
androID的特色之二:进程资源并没被销毁,Activity的主线程也是没有退出的,因此Activity中的消息队列会一致执行下去,当再此启动Activity的时候,又会实例化一Rrunnable,又会向此消息队列中添加一个这个Runnable。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
总结以上是内存溢出为你收集整理的Android 开发中线程的分析全部内容,希望文章能够帮你解决Android 开发中线程的分析所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)