目前遇到一个问题程序需要一直运行,并显示在最前端,但是运行一段时间发现会被系统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 app不被kill.docx
在Android中,如果想退出Android程序,一般都是调用finish()、System.exit(0)android.os.Process.killProcess(android.os.Process.myPid())等方法来实现退出程序功能,可是在实际开发中,并不能达到完全退出应用程序...
Android Service被关闭后自动重启,解决被异常kill 服务
Android获取正在运行程序并kill掉
Android Kill
从界面跳转后被系统Kill来看Activity的方法调用 博文地址 http://blog.csdn.net/ak5700/article/details/17138623
可以对Android的进程获取并清理掉 之前的下载链接资源有密码,但是CSDN无法修改资源,这是后来无密码的
强力推荐,Android Kill(最好用的Android apk反编译软件) Android Killer是一款可以对APK进行反编译的工具,它能够对反编译后的Smali文件进行修改,并将修改后的文件进行打包
当crash发生时,系统会kill掉你的程序,表现就是闪退或者程序已停止运行,这对用户来说是很不友好的,也是开发者所不愿意看到的,更糟糕的是,当用户发生了crash,开发者却无法得知程序为何crash,即便你想去解决这...
Android实现双进程守护,如何保证Service不被Kill,onStartCommand方法,返回START_STICKY,手动返回START_STICKY,亲测当service因内存不足被kill,当内存又有的时候,service又被重新创建,比较不错,但是不能保证...
linux kill杀不掉进程的原因,及解决办法.zip
Windows环境中Kill掉Oracle线程
pskill pskill 杀掉进程,win2000等系统使用。 可杀掉系统进程
KILLSQL防止注入,无需创建类,直接调用静态方法,简单易用。
http://blog.csdn.net/qq_28690547/article/details/50375997;关于demo的文章详解,有兴趣的童鞋可以看看,解决popupwindow/dialog的BadTokenException异常
Android 11 修改最近任务栏无法kill正在播放的音乐
Service意外被kill利用监听来重新启动.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习。
VB杀死KILL进程的实例程序,程序运行后,指定某一个需要关闭的进程,可强制关闭其进程,杀死进程相关的线程,其实比较简单的方法,请细看代码吧。
Linux中Kill掉进程的10种方法.docx