防止Android程序被系统kill掉的处理方法
转载请注明出处:http://blog.csdn.net/cuiran/article/details/38851401
目前遇到一个问题程序需要一直运行,并显示在最前端,但是运行一段时间发现会被系统Kill掉,这样程序就退出回到了桌面,不能实现一直运行的效果。为了实现此效果,也想了一些办法。如下:
1、可以将应用改为系统应用——由于程序需要定期更新,如果被放入系统应用,更新会非常麻烦,故没有采用。
2、在软件的onDestroy()方法中,发送重新启动应用的广播——如果程序是直接被kill掉 不会调用onDestroy方法(如果有发现应用被kill掉还会调用此方法,可以留言告知,非常感谢!)
3、新建一个Service,在后台服务定时去检测对应package是否在运行,若没有运行就发送广播告知。
为了实现效果程序同时实现2,3两种方式。
首先新建一个apk将级别改为系统应用,需要添加
android:sharedUserId="android.uid.system"
在此apk中新建一个BroadcastReceiver用于接收重启程序的广播,收到广播会启动所需要运行的apk
然后在新建Service,在Service实现了对所需package是否运行和是否安装的检测,如果没有运行,再检测是否安装,若安装,会发送广播让其启动应用程序
/**
* CheckService.java
* Copyright(C) 2014
* creator:cuiran 2014-8-26 下午1:20:01
*/
package com.xsdl.count.service;
import java.util.List;
import java.util.Timer;
import java.util.TimerTask;
import com.xsdl.count.receiver.Constants;
import com.xsdl.count.util.LogsUtil;
import android.annotation.SuppressLint;
import android.app.ActivityManager;
import android.app.Service;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
/**
* 后台开启服务定时检测
* @author cuiran
* @version 1.0.0
*/
public class CheckService extends Service {
private static final String TAG="CheckService";
private static final String ProcessName = "com.ghyf.mplay";
@Override
public IBinder onBind(Intent arg0) {
return null;
}
/* (non-Javadoc)
* @see android.app.Service#onCreate()
*/
@Override
public void onCreate() {
LogsUtil.i(TAG, "检测服务启动---->>>> ");
taskMail = new TimerTask() {
@Override
public void run() {
Message message = new Message();
message.what = 1;
handlerMail.sendMessage(message);
}
};
timerMail.schedule(taskMail, 15000, 5000);
super.onCreate();
}
private final Timer timerMail = new Timer();
private TimerTask taskMail;
@SuppressLint("HandlerLeak")
Handler handlerMail = new Handler() {
@Override
public void handleMessage(Message msg) {
// 要做的事情
try {
boolean is=isBackgroundRunning();
LogsUtil.i(TAG, "检测播控器 "+ProcessName+" is "+is);
if(!is){
/**
* 发送广播通知应用启动
*/
if(checkPackage()){
Intent myIntent = new Intent(Constants.RESOFTWARE_RECEIVER);
myIntent.putExtra("path","test");
myIntent.setAction(Constants.RESOFTWARE_RECEIVER);
sendBroadcast(myIntent);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
};
ActivityManager activityManager=null;
PackageManager packageManager=null;
PackageInfo pi = null;
/**
* 检测package是否存在<br>
* 2014-8-26 下午3:58:49
* @return
*
*/
public boolean checkPackage() {
boolean flag=false;
packageManager = getPackageManager();
try {
pi = packageManager.getPackageInfo(ProcessName, 0);
if(null!=pi){
flag=true;
}
} catch (NameNotFoundException e) {
flag=false;
LogsUtil.e(TAG, "出现异常", e);
}
return flag;
}
/**
* 检测package是否在运行<br>
* 2014-8-26 下午3:58:49
* @return
*
*/
private boolean isBackgroundRunning() {
activityManager = (ActivityManager) getSystemService(ACTIVITY_SERVICE);
if (activityManager == null) return false;
// get running tasks processes
List<ActivityManager.RunningTaskInfo> processList = activityManager.getRunningTasks(100);
for (ActivityManager.RunningTaskInfo info : processList) {
if (info.topActivity.getPackageName().startsWith(ProcessName)) {
return true;
}
}
return false;
}
/* (non-Javadoc)
* @see android.app.Service#onDestroy()
*/
@Override
public void onDestroy() {
try {
/**
* 释放资源
*/
if(taskMail!=null){
taskMail.cancel();
}
if(timerMail!=null){
timerMail.cancel();
}
} catch (Exception e) {
LogsUtil.e(TAG, "出现异常", e);
}
super.onDestroy();
}
}
启动应用程序可以采用如下两种方式:
第一种是直接通过Android的startActivity
public void openCLD(String packageName,Context context) {
PackageManager packageManager = context.getPackageManager();
PackageInfo pi = null;
try {
pi = packageManager.getPackageInfo(packageName, 0);
} catch (NameNotFoundException e) {
LogsUtil.e("pi", "出现异常", e);
}
Intent resolveIntent = new Intent(Intent.ACTION_MAIN, null);
resolveIntent.addCategory(Intent.CATEGORY_LAUNCHER);
resolveIntent.setPackage(pi.packageName);
List<ResolveInfo> apps = packageManager.queryIntentActivities(resolveIntent, 0);
ResolveInfo ri = apps.iterator().next();
if (ri != null ) {
String className = ri.activityInfo.name;
Intent intent = new Intent(Intent.ACTION_MAIN);
intent.addCategory(Intent.CATEGORY_LAUNCHER);
ComponentName cn = new ComponentName(packageName, className);
intent.setComponent(cn);
context.startActivity(intent);
}
}
第二种是通过执行命令 am start package/package.Activity这种方式启动。
防止Android程序被系统kill掉的处理方法的更多相关文章
- 退出Android程序时清除所有activity的实现方法
思路: 1. 自定义ActivityList管理类,添加删除维护该list; 2.Activity Stack 类似上面: 3.singleTask定义一个Activity为该启动模式,然后当返回时, ...
- Android: HowTo设置app不被系统kill掉
有一种方法可以设置app永远不会被kill,AndroidManifest.xml 中添加: android:persistent="true" 适用于放在/system/app下 ...
- 让Android程序获得系统的权限,实现关机重启,静默安装等功能
引用:http://www.cnblogs.com/welenwho/archive/2012/05/10/2494984.html android想要获得系统权限有几种途径,一种就是你的程序固化的系 ...
- Android app被系统kill的场景
何时发生 当我们的app被切到后台的时候,比如用户按下了home键或者切换到了别的应用,总之是我们的app不再和用户交互了,这个时候对于我们的app来说就是什么事情都可能发生的时候了,因为系统会认为你 ...
- Android项目--浅析系统通讯录中的那些方法
系统通讯录,以前的版本虽然过时了,不过有些东西还是可以用. 1.开启系统联系人添加 /** 添加联系人 */ Intent intent = new Intent(Intent.ACTION_INSE ...
- Android 4.4系统获取root权限的方法
1. 准备工作: 准备一台ubuntu机器,将boot.img复制到该机器上,下载必要的工具sudo apt-get install abootimggit clone https://github. ...
- android 程序防止被360或者系统给kill掉
关于如果和防止android 程序防止被360kill掉之后重启的问题,肯定大家也搜索了好多方法,都不好使,对不对,什么增高权限了,什么进程优先级了,这些东西都不是我们可控的,所以有没有一些非常保险的 ...
- 如何让自己的Android程序永不被系统kill
一般来说,在Android系统中,当某进程较长时间不活动,或系统资源比较紧时,该进程可能被系统kill掉,以此来回收一些资源.Android系统会根据进程的优先级来选择性地杀死一些进程,优先级从高到低 ...
- 在Android程序中使用已有的SQLite数据库
已经将这篇文章迁移至 Code问答,你也能够到这里查看这篇文章,请多多关注我的新技术博客CodeWenDa.com 在中文搜索中,没有找到一篇比較好的关于怎样在Android应用中使用自己事先创建好的 ...
随机推荐
- Promise--优雅的异步回调解决方案
当一个接口需要依赖另一个接口的请求数据时,通常有两种解决方式,一个是将请求数据的接口设为同步,之后调另一个接口,另一个是在请求数据接口的成功回调里调另一个接口. 但是:当一个接口需要依赖很多个接口的请 ...
- jQuery 效果 – 滑动
jQuery 滑动方法可使元素上下滑动. 点击这里,隐藏/显示面板 一寸光阴一寸金,因此,我们为您提供快捷易懂的学习内容. 在这里,您可以通过一种易懂的便利的模式获得您需要的任何知识. 实例 jQue ...
- Nodejs 模块查找机制还不错(从当前目录开始逐级向上查找node_modules)
比如 m.js是能够调用a.js的, 这样子目录就可以避免重复安装node_modules. 够用了.
- Maven 核心原理
Maven 核心原理 标签 : Java基础 Maven 是每一位Java工程师每天都会接触的工具, 但据我所知其实很多人对Maven理解的并不深, 只把它当做一个依赖管理工具(下载依赖.打包), M ...
- AsyncTask函数化的封装,AsyncTask函数式的调用
AsyncTask在本专栏已经做过详细的解析,但是AsyncTask函数式的调用这个概念对大多数人来说比较陌生.其实本质就是自己封装AsyncTask,让暴露的方法,看不到一点AsyncTask的身影 ...
- Scala:函数和闭包
http://blog.csdn.net/pipisorry/article/details/52902271 Scala函数 Scala 有函数和方法,二者在语义上的区别很小.Scala 方法是类的 ...
- Lua热更新(hotfix)
Lua热更新(hotfix)(金庆的专栏)hotfixLua 5.2/5.3 hotfix. Hot update functions and keep old data.https://github ...
- [mysql]创建数据库并指定编码
现在用orm比较多,很多mysql表啊都不用自己创建,但是数据库还是要自己创建,记录下sql, 备忘. CREATE DATABASE `mydb` CHARACTER SET utf8 COLLAT ...
- [nginx]统计文件下载是否完整思路(flask)
有一个需求是统计文件是否被用户完整下载,因为是web应用,用js没有找到实现方案,于是搜索下nginx的实现方案,把简单的探索过程记录下. 实验一 最原始的思路,查看日志,下载了一个文件之后我们看日志 ...
- SQLite Update 语句(http://www.w3cschool.cc/sqlite/sqlite-update.html)
SQLite Update 语句 SQLite 的 UPDATE 查询用于修改表中已有的记录.可以使用带有 WHERE 子句的 UPDATE 查询来更新选定行,否则所有的行都会被更新. 语法 带有 W ...