热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android开发中线程的分析

这篇文章主要介绍了Android开发中线程的分析的相关资料,需要的朋友可以参考下

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键的时候,只是简单的将位于堆栈里下一个activity弹出,将原来的activity压栈而已,系统并保存原来的activity的一些历史信息,并不销毁,等你下次打开的时候,能够很快的恢复。

android的特色之二:进程资源并没被销毁,Activity的主线程也是没有退出的,因此Activity中的消息队列会一致执行下去,当再此启动Activity的时候,又会实例化一Rrunnable,又会向此消息队列中添加一个这个Runnable。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


推荐阅读
  • 本文介绍了Java编程语言的基础知识,包括其历史背景、主要特性以及如何安装和配置JDK。此外,还详细讲解了如何编写和运行第一个Java程序,并简要介绍了Eclipse集成开发环境的安装和使用。 ... [详细]
  • 万事开头难,凡事都有套路,勇敢迈出第一步就成功一大半了。本节将带领初学者们迈出属于自己的一小步。本书的开发工具采用AndroidStudio࿰ ... [详细]
  • 华为捐赠欧拉操作系统,承诺不推商用版
    华为近日宣布将欧拉开源操作系统捐赠给开放原子开源基金会,并承诺不会推出欧拉的商用发行版。此举旨在推动欧拉和鸿蒙操作系统的全场景融合与生态发展。 ... [详细]
  • 本文介绍了多种开源数据库及其核心数据结构和算法,包括MySQL的B+树、MVCC和WAL,MongoDB的tokuDB和cola,boltDB的追加仅树和mmap,levelDB的LSM树,以及内存缓存中的一致性哈希。 ... [详细]
  • Python多线程详解与示例
    本文介绍了Python中的多线程编程,包括僵尸进程和孤儿进程的概念,并提供了具体的代码示例。同时,详细解释了0号进程和1号进程在系统中的作用。 ... [详细]
  • 本文将介绍如何在混合开发(Hybrid)应用中实现Native与HTML5的交互,包括基本概念、学习目标以及具体的实现步骤。 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • 一个建表一个执行crud操作建表代码importandroid.content.Context;importandroid.database.sqlite.SQLiteDat ... [详细]
  • A*算法在AI路径规划中的应用
    路径规划算法用于在地图上找到从起点到终点的最佳路径,特别是在存在障碍物的情况下。A*算法是一种高效且广泛使用的路径规划算法,适用于静态和动态环境。 ... [详细]
  • NX二次开发:UFUN点收集器UF_UI_select_point_collection详解
    本文介绍了如何在NX中使用UFUN库进行点收集器的二次开发,包括必要的头文件包含、初始化和选择点集合的具体实现。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • MySQL 数据库连接方法
    本文介绍了如何使用 MySQL 命令行工具连接到指定的数据库。 ... [详细]
  • 在 Mac 上配置 NDK
    本文详细介绍了如何在 Mac 上配置 Android NDK,包括设置环境变量和解决常见问题的方法。 ... [详细]
  • 如何解决8080端口被占用问题
    本文介绍了如何通过命令行和任务管理器查找并终止占用8080端口的进程,以确保该端口能够正常使用。 ... [详细]
  • Excel 数据分析基础
    Excel 是数据分析中最基本且强大的工具之一,具备多种实用功能和操作方法。本文将简要介绍 Excel 的不同版本及其兼容性问题,并探讨在处理大数据时的替代方案。 ... [详细]
author-avatar
沉佩颖岳玲
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有