android activity管理机制,使用弱引用的activity栈管理机制
本人最新公众号,汇集了各个公众号的优秀文章,进行分类整理,让大家能够更方便的查阅,希望大家多多支持,来个关注奥,一个号,顶一堆号。
在开发过程中,我们常常会用到一个常用的东西,就是activity栈,这个东西得作用就是处理逻辑,在某些情况下直接可以将所有的activity关闭,或者只保留1个指定的activity。
但是很多的栈管理器都是使用强引用写的,这样就容易引起app崩溃,因为activity在某些时候回被系统回收,然后返回后重新创建,这时弱引用的优势就来了,就是他不会直接使用该对象(强引用会),你可以判断他要使用的对象是否为空,这时,很多的崩溃情况就可以被避免了,下面上代码:
/**
* Author: 姚智胜
* Version: V1.0版本
* Description: activity栈管理器
* Date: 2017/04/22.
*/
public class ActivityStackManager {
private static final String TAG = "ActivityStackManager";
/**
* Activity栈
*/
private Stack> mActivityStack;
private static ActivityStackManager activityStackManager = new ActivityStackManager();
private ActivityStackManager() {
}
/***
* 获得AppManager的实例
*
* @return AppManager实例
*/
public static ActivityStackManager getInstance() {
if (activityStackManager == null) {
activityStackManager = new ActivityStackManager();
}
return activityStackManager;
}
/***
* 栈中Activity的数
*
* @return Activity的数
*/
public int stackSize() {
return mActivityStack.size();
}
/***
* 获得Activity栈
*
* @return Activity栈
*/
public Stack> getStack() {
return mActivityStack;
}
/**
* 添加Activity到堆栈
*/
public void addActivity(WeakReference activity) {
if (mActivityStack == null) {
mActivityStack = new Stack<>();
}
mActivityStack.add(activity);
}
/**
* 删除ac
*
* @param activity 弱引用的ac
*/
public void removeActivity(WeakReference activity) {
if (mActivityStack != null) {
mActivityStack.remove(activity);
}
}
/***
* 获取栈顶Activity(堆栈中最后一个压入的)
*
* @return Activity
*/
public Activity getTopActivity() {
Activity activity = mActivityStack.lastElement().get();
if (null == activity) {
return null;
} else {
return mActivityStack.lastElement().get();
}
}
/***
* 通过class 获取栈顶Activity
*
* @param cls
* @return Activity
*/
public Activity getActivityByClass(Class> cls) {
Activity return_activity = null;
for (WeakReference activity : mActivityStack) {
if (activity.get().getClass().equals(cls)) {
return_activity = activity.get();
break;
}
}
return return_activity;
}
/**
* 结束栈顶Activity(堆栈中最后一个压入的)
*/
public void killTopActivity() {
try {
WeakReference activity = mActivityStack.lastElement();
killActivity(activity);
} catch (Exception e) {
Log.e(TAG, e.getMessage());
}
}
/***
* 结束指定的Activity
*
* @param activity
*/
public void killActivity(WeakReference activity) {
try {
Iterator> iterator = mActivityStack.iterator();
while (iterator.hasNext()) {
WeakReference stackActivity = iterator.next();
if (stackActivity.get() == null) {
iterator.remove();
continue;
}
if (stackActivity.get().getClass().getName().equals(activity.get().getClass().getName())) {
iterator.remove();
stackActivity.get().finish();
break;
}
}
} catch (Exception e) {
Log.e(TAG, e.getMessage());
}
}
/***
* 结束指定类名的Activity
*
* @param cls
*/
public void killActivity(Class> cls) {
try {
ListIterator> listIterator = mActivityStack.listIterator();
while (listIterator.hasNext()) {
Activity activity = listIterator.next().get();
if (activity == null) {
listIterator.remove();
continue;
}
if (activity.getClass() == cls) {
listIterator.remove();
if (activity != null) {
activity.finish();
}
break;
}
}
} catch (Exception e) {
Log.e(TAG, e.getMessage());
}
}
/**
* 结束所有Activity
*/
public void killAllActivity() {
try {
ListIterator> listIterator = mActivityStack.listIterator();
while (listIterator.hasNext()) {
Activity activity = listIterator.next().get();
if (activity != null) {
activity.finish();
}
listIterator.remove();
}
} catch (Exception e) {
Log.e(TAG, e.getMessage());
}
}
/**
* 移除除了某个activity的其他所有activity
*
* @param cls 界面
*/
public void killAllActivityExceptOne(Class cls) {
try {
for (int i = 0; i < mActivityStack.size(); i++) {
WeakReference activity = mActivityStack.get(i);
if (activity.getClass().equals(cls)) {
break;
}
if (mActivityStack.get(i) != null) {
killActivity(activity);
}
}
} catch (Exception e) {
Log.e(TAG, e.getMessage());
}
}
/**
* 退出应用程序
*/
public void AppExit(Context context) {
killAllActivity();
Process.killProcess(Process.myPid());
}
}
赶快试试吧,如果你感兴趣,可以看看我在github的开源项目:
直通车
里面有很多实用的东西去看看吧,喜欢的话给个star呀
本博客不定期更新╮(╯▽╰)╭╮(╯▽╰)╭
android activity管理机制,使用弱引用的activity栈管理机制相关推荐
- Handler造成Activity泄漏,用弱引用真的有用么?
网上很多教程,解决Handler造成的内存泄漏问题,基本上是使用弱引用来解决的,但是使用弱引用真的有效么?直接写代码演示,以及分析. 下面分析过程分为4种,第一种是Handler声明成静态的并且弱引用 ...
- Android学习笔记之SoftReference软引用,弱引用WeakReference
SoftReference可以用于bitmap缓存 WeakReference 可以用于handler 非静态内部类和匿名内部类容易造成内存泄漏 private Handler mRemoteHand ...
- 【Android 内存优化】Java 引用类型 ( 强引用 | 软引用 | 弱引用 | 虚引用 )
文章目录 一. Java 引用类型 ( 强.软.弱.虚 ) 二. 软引用代码示例 三. 弱引用代码示例 强引用 ( 不回收 ) > 软引用 ( OOM 前回收 ) > 弱引用 ( GC 必 ...
- 理解Java中的弱引用(Weak Reference)
理解Java中的弱引用(Weak Reference) 本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限, ...
- java弱引用怎么手动释放,十分钟理解Java中的弱引用,十分钟java引用
十分钟理解Java中的弱引用,十分钟java引用 本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,帮助大家理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限 ...
- java的弱引用_理解Java中的弱引用(Weak Reference)
本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限,叙述中难免存在不准确或是不清晰的地方,希望大家可以指出, ...
- iOS 中集合如何弱引用对象
1. 使用 NSValue NSValue 可以弱引用保存一个对象,我们可以使用这种方法间接的引用. NSValue *value = [NSValue valueWithNonretainedObj ...
- JDK源码系列:ThreadLocal弱引用真的是过度设计吗?
在<码处高效:Java开发手册>这本书上详细描述了ThreadLocal的原理,也有过度设计的说法, 难道弱引用设计真的没必要吗?对此老吕要仔细分析分析,ThreadLocal到底该不该使 ...
- 【Android 内存优化】Bitmap 内存缓存 ( Bitmap 内存复用 | 弱引用 | 引用队列 | 针对不同 Android 版本开发不同的 Bitmap 复用策略 | 工具类代码 )
文章目录 一.Bitmap 复用池 二.弱引用 Bitmap 内存释放 三.从 Bitmap 复用池中获取对应可以被复用的 Bitmap 对象 1.Android 2.3.3(API 级别 10)及以 ...
最新文章
- 迪杰斯特拉算法——PAT 1003
- 深度学习数据集制作工作_创建我的第一个深度学习+数据科学工作站
- 图像数据格式基础知识
- VBoxManage: error: Nonexistent host networking interface, name 'vboxnet0' (VERR_INTERNAL_ERROR)
- 史玉柱吃透了中国人的人性,也引发了争议
- 拿不出双十一成绩单,垂直电商何以安身立命?
- redis在linux中安装目录,小刀博客园
- chrome无法打开某些网页,但safari可以
- 米莱迪机器人加物理攻击_自拍、航拍、运动拍“ALL IN ONE”,臻迪PowerEgg X开启全新未来...
- python: SHA256算法的实现和消息的哈希散列值计算
- could not access network location \Hewlett-Packard\\
- ERStudio 安装
- 最好用的数据分析软件jmp16中文版
- Linux CentOS 6不能使用yum安装命令
- 优秀前端工程师必备: checkbox radio--单钩 多钩 大比较:你是♂||♀ , 还是 ♂♀...
- 算法(赛马问题)图解
- 苹果支付(内购项目)回调验证
- Android系统分析之带着问题看事件分发机制
- 一花一树一城,走进三维重建的绚丽世界|专访权龙
- 借游戏带动“卖铲”收益,“卖铲子”的Unity借元宇宙起飞?