关于Android 4.0 以上Service被kill后的生命周期 以及onTaskRemoved和OnTrimMemory调用

本文主要是介绍关于Android 4.0 以上Service被kill后的生命周期 以及onTaskRemoved和OnTrimMemory调用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一直在搞基础的安卓Service ,估计很多人都一样,最头疼的是Service被kill后的生命周期

 

先贴出服务代码:

 
  1. public class MyService extends Service {

  2.  
  3. @Override

  4. public void onCreate() {

  5. super.onCreate();

  6. Log.v("tag", "服务:onCreate");

  7.  
  8. }

  9.  
  10. @Override

  11. public void onDestroy() {

  12. super.onCreate();

  13. Log.v("tag", "服务:onDestroy");

  14. }

  15.  
  16. @Override

  17. public int onStartCommand(Intent intent, int flags, int startId) {

  18. Log.v("tag", "服务:onStartCommand");

  19. return super.onStartCommand(intent, flags, startId);

  20. }

  21.  
  22. @Override

  23. public void onRebind(Intent it) {

  24. super.onRebind(it);

  25. Log.v("tag", "服务:onRebind");

  26. }

  27.  
  28. @Override

  29. public boolean onUnbind(Intent it) {

  30. Log.v("tag", "服务:onUnbind");

  31. return super.onUnbind(it);

  32.  
  33. }

  34.  
  35. public class IBinderImpl extends Binder {

  36. public MyService getInstance() {

  37. return MyService.this;

  38. }

  39. };

  40.  
  41. @Override

  42. public IBinder onBind(Intent intent) {

  43. Log.v("tag", "服务:onBind");

  44. return new IBinderImpl();

  45. }

  46.  
  47. @SuppressWarnings("deprecation")

  48. @Override

  49. public void onStart(Intent intent, int startId) {

  50. // TODO Auto-generated method stub

  51. super.onStart(intent, startId);

  52. Log.v("tag", "服务:onStart");

  53. }

  54.  
  55. @Override

  56. public void onConfigurationChanged(Configuration newConfig) {

  57. // TODO Auto-generated method stub

  58. super.onConfigurationChanged(newConfig);

  59. Log.v("tag", "服务:onStart");

  60. }

  61.  
  62. @Override

  63. public void onLowMemory() {

  64. // TODO Auto-generated method stub

  65. super.onLowMemory();

  66. Log.v("tag", "服务:onLowMemory");

  67. }

  68.  
  69. @SuppressLint("NewApi")

  70. @Override

  71. public void onTrimMemory(int level) {

  72. // TODO Auto-generated method stub

  73. super.onTrimMemory(level);

  74. Log.v("tag", "服务:onTrimMemory " + level);

  75. }

  76.  
  77. @SuppressLint("NewApi")

  78. @Override

  79. public void onTaskRemoved(Intent rootIntent) {

  80. // TODO Auto-generated method stub

  81. super.onTaskRemoved(rootIntent);

  82. Log.v("tag", "服务:onTaskRemoved");

  83. }

  84.  
  85. @Override

  86. protected void dump(FileDescriptor fd, PrintWriter writer, String[] args) {

  87. // TODO Auto-generated method stub

  88. super.dump(fd, writer, args);

  89. Log.v("tag", "服务:dump");

  90. }

  91.  
  92.  
  93.  
  94. }

 

MainActivity代码:

 

 
  1. public class MainActivity extends ActionBarActivity implements OnClickListener {

  2.  
  3. private Button startServiceBtn;

  4.  
  5. @Override

  6. protected void onCreate(Bundle savedInstanceState) {

  7. super.onCreate(savedInstanceState);

  8. setContentView(R.layout.activity_main);

  9. startServiceBtn = (Button) findViewById(R.id.startService);

  10.  
  11. startServiceBtn.setOnClickListener(this);

  12.  
  13. }

  14.  
  15. @Override

  16. public boolean onCreateOptionsMenu(Menu menu) {

  17. // Inflate the menu; this adds items to the action bar if it is present.

  18. getMenuInflater().inflate(R.menu.main, menu);

  19. return true;

  20. }

  21.  
  22. @Override

  23. public boolean onOptionsItemSelected(MenuItem item) {

  24. // Handle action bar item clicks here. The action bar will

  25. // automatically handle clicks on the Home/Up button, so long

  26. // as you specify a parent activity in AndroidManifest.xml.

  27. int id = item.getItemId();

  28. if (id == R.id.action_settings) {

  29. return true;

  30. }

  31. return super.onOptionsItemSelected(item);

  32. }

  33.  
  34. @Override

  35. public void onClick(View v) {

  36. // TODO Auto-generated method stub

  37. if(v.getId() == R.id.startService){

  38.  
  39. Intent intent = new Intent();

  40.  
  41. intent.setClass(this, MyService.class);

  42.  
  43. this.startService(intent);

  44.  
  45. }

  46.  
  47. }

  48. }

 

现在进行测试 :

1,连按三次button,查看服务的执行日志

说明在用startservice方式启动Service时 Create()方法只会被创建一起,再次startservice时会直接调用service的onStart函数和onStartCommand函数,这点应该很多人都知道吧

2,点击返回键之后Service执行步骤为(接着上面的):

发现Service 调用了 OnTrimMemory函数 ,很奇怪,有点不明白,有大侠懂的话可以告诉一下

3,退出软件后,用长按home调出最近运行历史,在这里面清除软件:

这时候Service调用了onTaskRemoved函数,同时在设置里面的应用管理里面可以发现这时候 Service的状态时 正在重启状态 ,于是启动后又调用了Create相关函数。

4,用最新版的360杀死软件后:

可以看到并没有调用taskremove函数,而是直接把它干了,这时候后台服务也消失,只能说360杀的太干净了,而且我发现我系统自带的清理工具杀死该软件是也是如此,杀的特别干净,而且Service不调用任何自己的函数

5,补充一下,在打开软件启动服务后,这时候点击home键 Service的执行过程如下:

 

6,在设置-应用管理里面-正在运行服务中,你手动点击停止服务时,Service调用:

Service调用了onDestroy()函数, 也就是说,就算用户手动停止了Service,Service也会正常走完自己的生命周期,而不会受到干扰

 

至此完成了所有测试,测试时间 2014-10-16 ,机型 华为荣耀H30-T10

 

在一般情况下 没调用onTaskRemoved函数的话 Service是正常的在后台运行的,如果调用了,服务可能会处于正在重启的状态,这是我总结发现的,不知道大家有没有什么新发现。当然如果直接被360等干了,那就另外说,我说的这是一般没有其他软件干扰的情况下

 

以上只是测试startservice方法启动的service的执行过程,没有测试bind方式,有机会的话在测试,一直不知道怎么才能有效的保留后台服务,如果各位大侠有什么新研究的话可否联系我,带我一起深入底层研究哎

这篇关于关于Android 4.0 以上Service被kill后的生命周期 以及onTaskRemoved和OnTrimMemory调用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973185

相关文章

Android_04_网络图片查看器

1>不带缓存的图片查看器 MainActivity.java package com.ithiema.imageviewer;import java.io.InputStream;import java.net.HttpURLConnection;import java.net.MalformedURLException;import java.net.URL;import jav

Android_03_数据库的使用总结

前言: 1>区分SQL和SQLite SQL 是一门 ANSI 的标准计算机语言,用来访问和操作数据库系统。SQL 语句用于取回和更新数据库中的数据。 SQL 可与数据库程序协同工作,比如 MS Access、DB2、Informix、MS SQL Server、Oracle、Sybase 以及其他数据库系统。 不幸地是,存在着很多不同版本的 SQL 语言,但是为了与 ANSI 标准相

Android_03_单元测试框架

测试类(用于单元测试之用) package com.itheima.junit.test;import com.itheima.junit.utils.Utils;import android.test.AndroidTestCase;public class TestCase extends AndroidTestCase {public void test(){int result =

Android_02_关于SharePreferences的使用

前言: 我们使用SharePreferences的主要目的是针对一些简单的数据进行存取,其是通过键值对来存取的, 其实质是通过xml文件进行保存的;对于一些简单数据的存取,我们可以用SharePreferences,替代 其他几种复杂的数据存取的方式,比如文件的读写或者数据库的操作; 本示例演示的内容是:通过SharedPreferences来实现记住密码的功能,无需第二次再输入密码

Android_02_文件访问权限(待更新)

前言: 打开 File Explorer可以看到: 10个字母表示的意义: drwxrwxrwx 第一个字母:     * d:表示文件夹     * -:表示文件  第一组rwx:表示的是文件拥有者(owner)对文件的权限     * r:read,读     * w:write     * x:execute  第二组rwx:表示的是跟

Android_02_获取SD卡的可用容量

代码示例如下: package com.itheima.getsdavail;import java.io.File;import android.os.Build;import android.os.Bundle;import android.os.Environment;import android.os.StatFs;import android.app.Activity;i

Android_02_在内部或外部存储中读写文件的操作

前言:  Ram内存:运行内存,相当于电脑的内存  Rom内存:内部存储空间,相当于电脑的硬盘 sd卡:外部存储空间,相当于电脑的移动硬盘 1>在内部存储中读写文件 代码示例如下: package com.itheima.rwinrom;import java.io.BufferedReader;import java.io.File;import java.io.File

Android_02_帧布局

代码示例如下: <?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent" ><!-- 帧布

Android_02_相对布局

代码如下: <?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent" ><!--

在android的同一个wifi局域网下,利用socket与多个手机进行数据的收发

前言: 在这里强调局域网,是因为内网之间的设备通信时,无需经过外网,若想内网的设备能够与外网进行通信,可自行百度其解决办法... 虽说利用wifi,实质是怎么利用socket来进行通信的问题 步骤一:编写服务端和客户端的代码 服务端代码(MainActivity.java): package com.example.dai.wifiserver;import android