Android中如何像 360 一样优雅的杀死后台服务而不启动

Android中,虽然有很多方法(API或者shell命令)杀死后台`service`,但是仍然有很多程序几秒内再次启动,导致无法真正的杀死。这里主要着重介绍如何像 360 一样杀死Android后台服务,而不会再次启动。

一、已知的 kill 后台应用程序的方法

  • android.os.Process.killProcess(pid);
  • activityManager.killBackgroundProcesses(pkgName);
  • kill -9 pid

这三种方法都可以“杀死”后台应用程序,但是都会自启动,对于前面两种直接使用Android的API就行了,所以就不多介绍了。这里稍微介绍一下 最后一个方法的用法: kill -9 pid;

方法: kill -9 pid

这其实是一条shell 命令,我们知道Android的底层是Linux系统,所以在Android上可以使用所有的Linux终端命令。那么如何结合在代码中呢,贴一段代码


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

private void killProcess(String pid) {

    Process sh = null;

    DataOutputStream os = null;

    try {

        sh = Runtime.getRuntime().exec("su");

        os = new DataOutputStream(sh.getOutputStream());

        final String Command = "kill -9 " + pid + "\n";

        os.writeBytes(Command);

        os.flush();

    } catch (IOException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

    try {

        sh.waitFor();

    } catch (InterruptedException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

}

该方法最重要的功能就是告诉你,怎么在Android程序中执行Linux shell 命令


二、终极方法,杀死后台service而不自启动: am (Activity Manager)命令

相信很多人对 am 命令都挺熟悉的,它是Android系统中/system/bin/目录下的一条命令。不仅可以在终端下启动一个应用程序,还可以启动Service,发送 bro


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

private void forceStopAPK(String pkgName){

    Process sh = null;

    DataOutputStream os = null;

    try {

        sh = Runtime.getRuntime().exec("su");

        os = new DataOutputStream(sh.getOutputStream());

        final String Command = "am force-stop "+pkgName+ "\n";

        os.writeBytes(Command);

        os.flush();

    } catch (IOException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

    try {

        sh.waitFor();

    } catch (InterruptedException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

}

通过上面的这段代码,我们调用forceStopAPK方法,传递一个应用程序的包名,那么我们就可以杀死对应的Android程序,而不会自动启动。亲测:微信,淘宝,酷我,等一系列应用,杀死后不会再启动!Android中,虽然有很多方法(API或者shell命令)杀死后台`service`,但是仍然有很多程序几秒内再次启动,导致无法真正的杀死。这里主要着重介绍如何像 360 一样杀死Android后台服务,而不会再次启动。

一、已知的 kill 后台应用程序的方法

  • android.os.Process.killProcess(pid);
  • activityManager.killBackgroundProcesses(pkgName);
  • kill -9 pid

这三种方法都可以“杀死”后台应用程序,但是都会自启动,对于前面两种直接使用Android的API就行了,所以就不多介绍了。这里稍微介绍一下 最后一个方法的用法: kill -9 pid;

方法: kill -9 pid

这其实是一条shell 命令,我们知道Android的底层是Linux系统,所以在Android上可以使用所有的Linux终端命令。那么如何结合在代码中呢,贴一段代码


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

private void killProcess(String pid) {

    Process sh = null;

    DataOutputStream os = null;

    try {

        sh = Runtime.getRuntime().exec("su");

        os = new DataOutputStream(sh.getOutputStream());

        final String Command = "kill -9 " + pid + "\n";

        os.writeBytes(Command);

        os.flush();

    } catch (IOException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

    try {

        sh.waitFor();

    } catch (InterruptedException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

}

该方法最重要的功能就是告诉你,怎么在Android程序中执行Linux shell 命令


二、终极方法,杀死后台service而不自启动: am (Activity Manager)命令

相信很多人对 am 命令都挺熟悉的,它是Android系统中/system/bin/目录下的一条命令。不仅可以在终端下启动一个应用程序,还可以启动Service,发送 broadcast以及Intent actionforce stop process 等等,功能非常强大。这里我们要用到一个功能就是强制停止应用程序!
对于命令 am 的介绍与用法,官网给的非常情况,请参照Android 官网: http://developer.android.com/tools/help/adb.html#am

我们用到的方法和功能是:am force-stop <PACKAGE>
下面是我们的代码举例


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

private void forceStopAPK(String pkgName){

    Process sh = null;

    DataOutputStream os = null;

    try {

        sh = Runtime.getRuntime().exec("su");

        os = new DataOutputStream(sh.getOutputStream());

        final String Command = "am force-stop "+pkgName+ "\n";

        os.writeBytes(Command);

        os.flush();

    } catch (IOException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

    try {

        sh.waitFor();

    } catch (InterruptedException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }

}

通过上面的这段代码,我们调用forceStopAPK方法,传递一个应用程序的包名,那么我们就可以杀死对应的Android程序,而不会自动启动。亲测:微信,淘宝,酷我,等一系列应用,杀死后不会再启动!

时间: 2024-11-04 02:23:54

Android中如何像 360 一样优雅的杀死后台服务而不启动的相关文章

Android中如何像 360 一样优雅的杀死后台Service而不启动

http://my.oschina.net/mopidick/blog/277813 目录[-] 一.已知的 kill 后台应用程序的方法 方法: kill -9 pid 二.终极方法,杀死后台service而不自启动: am (Activity Manager)命令 一.已知的 kill 后台应用程序的方法 android.os.Process.killProcess(pid); activityManager.killBackgroundProcesses(pkgName); kill -9

Android中ActivityManager学习笔记(3)

在之前写过2篇关于ActivityManager的文章,如下所示.都是通过实战去了解里面的信息,现在感觉太繁琐,所以做一个api介绍比较详细.就像之前学习Telephony那样,对整体了解整个ActivityManager很有用. Android中ActivityManager学习笔记(1)-MemoryInfo Android中ActivityManager学习笔记(2)-RunningServiceInfo ActivityManager android.app包,含有6个内部类: Memo

Android中的ueventd

前言 与Linux相同,Android中的应用程序通过设备驱动访问硬件设备.设备节点文件是设备驱动的逻辑文件,应用程序使用设备节点文件来访问驱动程序. 在Linux中,运行所需的设备节点文件被被预先定义在"/dev"目录下.应用程序无需经过其它步骤,通过预先定义的设备节点文件即可访问设备驱动程序. 但根据Android的init进程的启动过程,我们知道,Android根文件系统的映像中不存在"/dev"目录,该目录是init进程启动后动态创建的. 因此,建立Anro

Android中bindService的使用及Service生命周期

Android中有两种主要方式使用Service,通过调用Context的startService方法或调用Context的bindService方法,本文只探讨纯bindService的使用,不涉及任何startService方法调用的情况.如果想了解startService相关的使用,请参见<Android中startService的使用及Service生命周期>. bindService启动服务的特点 相比于用startService启动的Service,bindService启动的服务

Android中的AlarmManager的使用

1.AlarmManager,顾名思义,就是"提醒",是Android中常用的一种系统级别的提示服务,在特定的时刻为我们广播一个指定的Intent.简单的说就是我们设定一个时间,然后在该时间到来时,AlarmManager为我们广播一个我们设定的Intent,通常我们使用 PendingIntent,PendingIntent可以理解为Intent的封装包,简单的说就是在Intent上在加个指定的动作.在使用Intent的时候,我们还需要在执行startActivity.startSe

Android 中延时执行的几种方法

延时执行的方法主要有: 1.开启新线程:2.利用定时器:3.消息处理:4.利用AlarmManager 一.开启新线程 new Thread(new Runnable(){ public void run(){ Thread.sleep(XXXX); handler.sendMessage(); //告诉主线程执行任务 } }).start 二.利用定时器 TimerTask task = new TimerTask(){ public void run(){ //execute the tas

android如何做到类似于微信那样后台服务不会被杀死?

问题描述 正在做一款锁屏应用. 做锁屏肯定用到了service,可是我发现每日手动点击自带的内存清理按钮的时候,我的那个service总是会被杀死. 而微信的后台服务却是一直正常的运行,不会被杀掉. 360的话也不会被杀死,但是360会重新启动.而且360的是两个后台服务,我猜有可能会相互作用的,杀死一个的时候另一个接收到广播把其重启. 尝试过用startForeground以及提高service优先级的方式,发现都不行,service都会被杀死. 反编译了一下微信的代码. 请大家帮忙想想办法吧

Android中如何优雅地自定义一个View

Android中自定义View的实现比较简单,无非就是继承父类,然后重载方法,即便如此,在实际编码中难免会遇到一些坑,我把自己遇到的一些问题和解决方法总结一下,希望对广大码友们有所帮助. 注意点① 用xml定义Layout时,Root element 最好使用merge 当我们需要继承一个布局比较复杂的ViewGroup(比较多的是LinearLayout.RelativeLayout)时,通常会用xml来写布局,然后在自定义的View类中inflate这个定义了layout的xml文件. 首先

Android基础入门教程——8.1.2 Android中的13种Drawable小结 Part 2

Android基础入门教程--8.1.2 Android中的13种Drawable小结 Part 2 标签(空格分隔): Android基础入门教程 本节引言: 本节我们继续来学习Android中的Drawable资源,上一节我们学习了: ColorDrawable:NinePatchDrawable: ShapeDrawable:GradientDrawable!这四个Drawable~ 而本节我们继续来学习接下来的五个Drawable,他们分别是: BitmapDrawable:Insert