1、问题的缘由
当APP应用程序是通过socket通信,或者SignalR通信时,或者像某些长连接如聊天的一些应用,为了让APP应用处于一个与服务器进行连接通信的长连接状态时,减少资源的耗损等时。需要解决该现象问题。当然,如果我们一直进行长连接通信也行,如QQ、微信等,但是有些应用没必要怎么做,毕竟这只是改应用的一个小模块。
2、解决问题方式
由以上问题,我们可以发现,一般是在APP处于后台时关闭通信,然后处于前台时,进行通信连接就可以了,那么我们该怎么做呢?
1、一般在什么情况下会出现APP处于后台,这是一个我们必须探讨的问题,然后呢,当APP处于前台时,要如何进行逻辑代码编写方式进行通信呢等等?
2、在一般情况下,我们都知道当点击HOME键时,APP会处于后台,并执行Activity的 onPuase()、onStop() 两个生命周期,但是问题是并不是只有点击HOME键才出现APP在后台。所以我们可以同=通过Application的全局状态来监听当前APP应用是否处于后台,或者运行在前台的作用。
3、代码code
创建全局的MyApp 记得在manifests添加 android:name="MyApp"属性
public class MyApp extends Application implements Application.ActivityLifecycleCallbacks {
int lifecyclecount = 0;
private static final String TAG = MyApp.class.getSimpleName();
@Override
public void onCreate() {
super.onCreate();
initLifecycleCallback();
}
private void initLifecycleCallback() {
registerActivityLifecycleCallbacks(this);
}
@Override
public void onActivityCreated(Activity activity, Bundle bundle) {
}
@Override
public void onActivityStarted(Activity activity) {
if(lifecyclecount == 0){
Log.e(TAG, "当前状态处于前台>>>>Started" + activity);
}
lifecyclecount++;
}
@Override
public void onActivityResumed(Activity activity) {
}
@Override
public void onActivityPaused(Activity activity) {
}
@Override
public void onActivityStopped(Activity activity) {
lifecyclecount--;
if (lifecyclecount == 0) {
Log.e(TAG, "当前状态处于后台>>>>Stopped" + activity);
}
}
@Override
public void onActivitySaveInstanceState(Activity activity, Bundle bundle) {
}
@Override
public void onActivityDestroyed(Activity activity) {
}
}
一般在BaseActivity进行对一下代码添加
private boolean isCurrenApptRunningForeground = true;
private static final String TAG = BaseActivity.class.getSimpleName();
@Override
protected void onStart() {
super.onStart();
if (!isCurrenApptRunningForeground) {
Log.e(TAG, "App应用程序处于前台中...");
//进行逻辑处理如果与服务器连接断开,就重新连接
}
}
@Override
protected void onStop() {
super.onStop();
isCurrenApptRunningForeground = isAppRunningForeground();
if (!isCurrentRunningForeground) {
Log.e(TAG, "App应用程序处于后台中...");
//可以断开服务器连接,相关需要等
}
}
public boolean isAppRunningForeground() {
ActivityManager activityManager = (ActivityManager) this.getSystemService(Context.ACTIVITY_SERVICE);
List<ActivityManager.RunningAppProcessInfo> appProcessInfos = activityManager.getRunningAppProcesses();
for (ActivityManager.RunningAppProcessInfo appProcessInfo : appProcessInfos) {
if (appProcessInfo.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
if (appProcessInfo.processName.equals(this.getApplicationInfo().processName)) {
Log.e(TAG, "处于前台运行中...");
return true;
}
}
}
Log.e(TAG, "处于后台运行中...");
return false;
}
4、对于这样的状态,我们已经完成了,所以大家可以在试试这样的方式,简洁的。