Intent intent = new Intent(context, MainActivity.class); intent.putExtra(“exit”, true); context.startActivity(intent); // 结束进程 // System.exit(0); } 优点 使用简单 & 方便 缺点 规定 App的入口Activity采用SingleTask启动模式 使用范围局限:只能结束当前任务栈的Activity,若出现多任务栈(即采用
SingleInstance
启动模式)则无法处理 应用场景 Activity单任务栈 方法2:采用Activity启动标记位 原理:对入口
Activity
采用 2 标记位:
Intent.FLAG_ACTIVITY_CLEAR_TOP
:销毁目标
Activity
和它之上的所有
Activity
,重新创建目标
Activity
Intent.FLAG_ACTIVITY_SINGLE_TOP
:若启动的
Activity
位于任务栈栈顶,那么此
Activity
的实例就不会重建,而是重用栈顶的实例( 调用
onNewIntent()
) 具体使用(从
MainActivity
(入口
Activity
) 跳转到
Activity2
& 一键退出) 步骤1:在
MainActivity
中设置 重写
onNewIntent()
MainActivity.java // 设置 按钮 跳转到Activity2 button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { startActivity(new Intent(MainActivity.this, Activity2.class)); } }); } // 在onNewIntent()传入一标识符 // 作用:标识是否要退出App @Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); if (intent != null) { // 是否退出App的标识 boolean isExitApp = intent.getBooleanExtra(“exit”, false); if (isExitApp) { // 关闭自身 this.finish(); } } // 结束进程 // System.exit(0); } } 步骤2:在需要退出的地方(
Activity2
)启动
MainActivity
& 设置标记位 // 当需要退出时,启动入口Activity Intent intent = new Intent(); intent.setClass(Activity2.this, MainActivity.class); // 设置标记位 intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); // 步骤1:该标记位作用:销毁目标Activity和它之上的所有Activity,重新创建目标Activity intent.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP); // 步骤2:若启动的Activity位于任务栈栈顶,那么此Activity的实例就不会重建,而是重用栈顶的实例( 调用实例的 onNewIntent() ) // 在步骤1中:MainActivity的上层的Activity2会被销毁,此时MainActivity位于栈顶;由于步骤2的设置,所以不会新建MainActivity而是重用栈顶的实例&调用实onNewIntent() // 传入自己设置的退出App标识 intent.putExtra(“exit”, true); startActivity(intent); 优点 使用简单 & 方便 缺点 使用范围局限:只能结束当前任务栈的Activity,若出现多任务栈(即采用
SingleInstance
启动模式)则无法处理 应用场景 Activity单任务栈 方法3:通过系统任务栈 原理:通过
ActivityManager
获取当前系统的任务栈 & 把栈内所有
Activity
逐个退出
具体使用
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
// 1. 通过Context获取ActivityManager
ActivityManager activityManager = (ActivityManager) context.getApplicationContext().getSystemService(Context.ACTIVITY_SERVICE);
// 2. 通过ActivityManager获取任务栈
List
SingleInstance
启动模式)则无法处理 对
Android
版本要求较高:
Android 5.0
以上 应用场景
Android 5.0
以上的
Activity
单任务栈 b. 通过 Android 组件: BroadcastReceiver 即使用
BroadcastReceiver
广播监听 原理:在每个
Activity
里注册广播接收器(响应动作 = 关闭自身);当需要退出
App
时 发送广播请求即可 具体实现 步骤1:自定义广播接收器 public class ExitAppReceiver extends BroadcastReceiver { private Activity activity; public ExitAppReceiver(Activity activity){ this.activity = activity; } @Override public void onReceive(Context context, Intent intent) { activity.finish(); } } 步骤2:在每个
Activity
里注册广播接收器(响应动作 = 关闭自身) public class Activity extends AppCompatActivity { private ExitAppReceiver mExitAppReceiver; // 1. 在onCreate()中注册广播接收器 protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mExitAppReceiver = new ExitAppReceiver(this); registerReceiver(mExitAppReceiver,new IntentFilter(BaseApplication.EXIT)); } // 1. 在onDestroy()中注销广播接收器 protected void onDestroy() { super.onDestroy(); unregisterReceiver(mExitAppReceive); } 步骤3:当需要退出App时 发送广播请求 context.sendBroadcast(new Intent(BaseApplication.EXIT)); // 注:此处不能使用:System.exit(0);结束进程 // 原因:发送广播这个方法之后,不会等到广播接收器收到广播,程序就开始执行下一句System.exit(0),然后就直接变成执行System.exit(0)的效果了。
优点 应用场景广泛:兼顾单 / 多任务栈 & 多启动模式的情况 缺点 实现复杂:需要在每个
Activity
里注册广播接收器 应用场景 任意情况下的一键退出 App,但无法终止
App
进程 所以该方法仅仅是在用户的角度来说 “一键退出App” c. 自身实现 方法1:创建 链表 原理:通过在
Application
子类中建立一个
Activity
链表:保存正在运行的
Activity
实例;当需要一键退出
App
时把链表内所有
Activity
实例逐个退出即可 具体使用 步骤1:在
BaseApplication
类的子类里建立
Activity
链表 Carson_BaseApplicaiton.java public class Carson_BaseApplicaiton extends Application { // 此处采用 LinkedList作为容器,增删速度快 public static LinkedList activityLinkedList; @Override public void onCreate() { super.onCreate(); activityLinkedList = new LinkedList<>(); registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() { @Override public void onActivityCreated(Activity activity, Bundle savedInstanceState) { Log.d(TAG, "onActivityCreated: " + activity.getLocalClassName()); activityLinkedList.add(activity); // 在Activity启动时(onCreate()) 写入Activity实例到容器内 } @Override public void onActivityDestroyed(Activity activity) { Log.d(TAG, "onActivityDestroyed: " + activity.getLocalClassName()); activityLinkedList.remove(activity); // 在Activity结束时(Destroyed()) 写出Activity实例 } @Override public void onActivityStarted(Activity activity) { } @Override public void onActivityResumed(Activity activity) { } @Override public void onActivityPaused(Activity activity) { } @Override public void onActivityStopped(Activity activity) { } @Override public void onActivitySaveInstanceState(Activity activity, Bundle outState) { } }); } public void exitApp() { Log.d(TAG, "容器内的Activity列表如下 "); // 先打印当前容器内的Activity列表 for (Activity activity : activityLinkedList) { Log.d(TAG, activity.getLocalClassName()); } Log.d(TAG, “正逐步退出容器内所有Activity”); // 逐个退出Activity for (Activity activity : activityLinkedList) { activity.finish(); } // 结束进程 // System.exit(0); } } // 记得在Manifest.xml中添加
App
时,获取该
Applicaiton
类对象 & 调用
exitApp()
private Carson_BaseApplicaiton app; app = (Carson_BaseApplicaiton)getApplication(); app.exitApp(); 效果图
优点 应用场景广泛:兼顾单 / 多任务栈 & 多启动模式的情况 缺点 需要
Activity
经历正常的生命周期,即创建时调用
onCreate()
,结束时调用
onDestroy()
因为只有这样经历正常的生命周期才能将
Activity
正确写入 & 写出 容器内 应用场景 任意情况下的一键退出
App
实现 方法2:RxBus 原理:使用
RxBus
当作事件总线,在每个
Activity
里注册
RxBus
订阅(响应动作 = 关闭自身);当需要退出App时 发送退出事件请求即可。
具体使用 步骤1:在每个
Activity
里注册
RxBus
订阅(响应动作 = 关闭自身) public class Activity extends AppCompatActivity { private Disposable disposable; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity2); // 注册RxBus订阅 disposable = RxBus.getInstance().toObservable(String.class) .subscribe(new Consumer() { @Override public void accept(String s) throws Exception { // 响应动作 = 关闭自身 if (s.equals(“exit”)){ finish(); } } }); } // 注意一定要取消订阅 @Override protected void onDestroy() { if (!disposable.isDisposed()){ disposable.dispose();; } } 步骤2:当需要退出App时 发送退出事件 RxBus.getInstance().post(“exit”); System.exit(0); 优点 可与
RxJava
&
RxBus
相结合 缺点 实现复杂:
RxBus
本身的实现难度 & 需要在每个
Activity
注册和取消订阅
RxBus
使用 应用场景 需要与
RxJava
结合使用时 若项目中没有用到
RxJava
&
RxBus
不建议使用 至此,一键结束当前
App
的所有
Activity
的 方法 讲解完毕。
注:上述方法仅仅只是结束当前
App
所有的
Activity
(在用户的角度确实是退出了
App
),但实际上该
App
的进程还未结束 2.2 (步骤2)一键结束当前 App 进程 主要采用
Dalvik VM
本地方法 作用 结束当前
Activity
& 结束进程 自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。
自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!
!
(备注:Android)
最后 答应大伙的备战金三银四,大厂面试真题来啦!
这份资料我从春招开始,就会将各博客、论坛。
网站上等优质的Android开发中高级面试题收集起来,然后全网寻找最优的解答方案。
每一道面试题都是百分百的大厂面经真题+最优解答。
包知识脉络 + 诸多细节。
节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
《960全网最全Android开发笔记》
《379页Android开发面试宝典》 包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。
熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。
如何使用它?
1.可以通过目录索引直接翻看需要的知识点,查漏补缺。
2.五角星数表示面试问到的频率,代表重要推荐指数
《507页Android开发相关源码解析》 只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。
腾讯、字节跳动、阿里、百度等BAT大厂 2020-2021面试真题解析
资料收集不易,如果大家喜欢这篇文章,或者对你有帮助不妨多多点赞转发关注哦。
文章会持续更新的。
绝对干货!
!
!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。
[外链图片转存中…(img-cwSAUPPR-1713756546523)] 腾讯、字节跳动、阿里、百度等BAT大厂 2020-2021面试真题解析 [外链图片转存中…(img-a9lQZiOd-1713756546525)] 资料收集不易,如果大家喜欢这篇文章,或者对你有帮助不妨多多点赞转发关注哦。
文章会持续更新的。
绝对干货!
!
!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
