本人最新公众号,汇集了各个公众号的优秀文章,进行分类整理,让大家能够更方便的查阅,希望大家多多支持,来个关注奥,一个号,顶一堆号。

在开发过程中,我们常常会用到一个常用的东西,就是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栈管理机制相关推荐

  1. Handler造成Activity泄漏,用弱引用真的有用么?

    网上很多教程,解决Handler造成的内存泄漏问题,基本上是使用弱引用来解决的,但是使用弱引用真的有效么?直接写代码演示,以及分析. 下面分析过程分为4种,第一种是Handler声明成静态的并且弱引用 ...

  2. Android学习笔记之SoftReference软引用,弱引用WeakReference

    SoftReference可以用于bitmap缓存 WeakReference 可以用于handler 非静态内部类和匿名内部类容易造成内存泄漏 private Handler mRemoteHand ...

  3. 【Android 内存优化】Java 引用类型 ( 强引用 | 软引用 | 弱引用 | 虚引用 )

    文章目录 一. Java 引用类型 ( 强.软.弱.虚 ) 二. 软引用代码示例 三. 弱引用代码示例 强引用 ( 不回收 ) > 软引用 ( OOM 前回收 ) > 弱引用 ( GC 必 ...

  4. 理解Java中的弱引用(Weak Reference)

    理解Java中的弱引用(Weak Reference) 本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限, ...

  5. java弱引用怎么手动释放,十分钟理解Java中的弱引用,十分钟java引用

    十分钟理解Java中的弱引用,十分钟java引用 本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,帮助大家理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限 ...

  6. java的弱引用_理解Java中的弱引用(Weak Reference)

    本篇文章尝试从What.Why.How这三个角度来探索Java中的弱引用,理解Java中弱引用的定义.基本使用场景和使用方法.由于个人水平有限,叙述中难免存在不准确或是不清晰的地方,希望大家可以指出, ...

  7. iOS 中集合如何弱引用对象

    1. 使用 NSValue NSValue 可以弱引用保存一个对象,我们可以使用这种方法间接的引用. NSValue *value = [NSValue valueWithNonretainedObj ...

  8. JDK源码系列:ThreadLocal弱引用真的是过度设计吗?

    在<码处高效:Java开发手册>这本书上详细描述了ThreadLocal的原理,也有过度设计的说法, 难道弱引用设计真的没必要吗?对此老吕要仔细分析分析,ThreadLocal到底该不该使 ...

  9. 【Android 内存优化】Bitmap 内存缓存 ( Bitmap 内存复用 | 弱引用 | 引用队列 | 针对不同 Android 版本开发不同的 Bitmap 复用策略 | 工具类代码 )

    文章目录 一.Bitmap 复用池 二.弱引用 Bitmap 内存释放 三.从 Bitmap 复用池中获取对应可以被复用的 Bitmap 对象 1.Android 2.3.3(API 级别 10)及以 ...

最新文章

  1. 迪杰斯特拉算法——PAT 1003
  2. 深度学习数据集制作工作_创建我的第一个深度学习+数据科学工作站
  3. 图像数据格式基础知识
  4. VBoxManage: error: Nonexistent host networking interface, name 'vboxnet0' (VERR_INTERNAL_ERROR)
  5. 史玉柱吃透了中国人的人性,也引发了争议
  6. 拿不出双十一成绩单,垂直电商何以安身立命?
  7. redis在linux中安装目录,小刀博客园
  8. chrome无法打开某些网页,但safari可以
  9. 米莱迪机器人加物理攻击_自拍、航拍、运动拍“ALL IN ONE”,臻迪PowerEgg X开启全新未来...
  10. python: SHA256算法的实现和消息的哈希散列值计算
  11. could not access network location \Hewlett-Packard\\
  12. ERStudio 安装
  13. 最好用的数据分析软件jmp16中文版
  14. Linux CentOS 6不能使用yum安装命令
  15. 优秀前端工程师必备: checkbox radio--单钩 多钩 大比较:你是♂||♀ , 还是 ♂♀...
  16. 算法(赛马问题)图解
  17. 苹果支付(内购项目)回调验证
  18. Android系统分析之带着问题看事件分发机制
  19. 一花一树一城,走进三维重建的绚丽世界|专访权龙
  20. 借游戏带动“卖铲”收益,“卖铲子”的Unity借元宇宙起飞?

热门文章

  1. PHP开源CMS系统 Typo3
  2. VoLTE高清通话是voip嘛
  3. 倍福TwinCAT(贝福Beckhoff)基础教程5.1 TwinCAT如何执行系统命令
  4. Word内容解析之图表数据获取
  5. 【SystemTap】 Linux下安装使用SystemTap源码安装SystemTap
  6. day17-Z字形变换
  7. 如何使用「预览」修改照片尺寸大小的技巧分享
  8. 国土面积c语言编程,土地利用规划试题
  9. 函数:判断表达式括弧是否匹配
  10. 常见的交易API接口介绍