先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip204888 (备注Android)
正文
3) HandlerThread
是一个带有Looper
的线程,在HandleThread
的run()方法中调用了Looper.prepare()
创建了Looper
实例,并调用Looper.loop()
开启了Loop循环,循环从消息队列中获取消息并交由Handler处理。利用该线程的Looper
创建Handler实例,此Handler的handleMessage()
方法是运行在子线程中的。即Handler利用哪个线程的Looper
创建的实例,它就和相应的线程绑定到一起,处理该线程上的消息,它的handleMessage()
方法就是在那个线程中运行的,无参构造默认是主线程。
HandlerThread
提供了quit()
/quitSafely()
方法退出HandlerThread
的消息循环,它们分别调用Looper
的quit和quitSafely
方法,quit会将消息队列中的所有消息移除,而quitSafely
会将消息队列所有延迟消息移除,非延迟消息派发出去让Handler去处理。
HandlerThread
适合处理本地IO读写操作(读写数据库或文件),因为本地IO操作耗时不长,对于单线程+异步队列不会产生较大阻塞,而网络操作相对比较耗时,容易阻塞后面的请求,因此HandlerThread
不适合加入网络操作。
- 3.handler发消息给子线程,looper怎么启动?
- 4.关于Handler,在任何地方new Handler 都是什么线程下?
- 5.ThreadLocal原理,实现及如何保证Local属性?
- 6.请解释下在单线程模型中Message、Handler、Message Queue、Looper之间的关系
- 7.请描述一下View事件传递分发机制
- 8.Touch事件传递流程
- 9.事件分发中的onTouch 和onTouchEvent 有什么区别,又该如何使用?
- 10.View和ViewGroup分别有哪些事件分发相关的回调方法
- 11.View刷新机制
- 12.View绘制流程
- 13.自定义控件原理
- 14.自定义View如何提供获取View属性的接口?
- 15.Android代码中实现WAP方式联网
- 16.AsyncTask机制
- 17.AsyncTask原理及不足
- 18.如何取消AsyncTask?
- 19.为什么不能在子线程更新UI?
- 20.ANR产生的原因是什么?
- 21.ANR定位和修正
- 22.oom是什么?
(oom(Out Of Memory)内存溢出) - 23.什么情况导致oom?
- 24.有什么解决方法可以避免OOM?
- 25.Oom 是否可以try catch?为什么?
(可以,当) - 26.内存泄漏是什么?
内存泄露就是指该被GC垃圾回收的,但被一个生命周期比它长的对象仍然在引用它,导致无法回收,造成内存泄露,过多的内存泄露会导致OOM。
27.什么情况导致内存泄漏?
1) 非静态内部类、匿名内部类:非静态内部类、匿名内部类 都会持有外部类的一个引用,如果有一个静态变量引用了非静态内部类或者匿名内部类,导致非静态内部类或者匿名内部类的生命周期比外部类(Activity)长,就会导致外部类在该被回收的时候,无法被回收掉,引起内存泄露, 除非外部类被卸载。
解决办法:将非静态内部类、匿名内部类 改成静态内部类,或者直接抽离成一个外部类。 如果在静态内部类中,需要引用外部类对象,那么可以将这个引用封装在一个WeakReference
中。
2)静态的View:当一个Activity经常启动,但是对应的View读取非常耗时,我们可以通过静态View变量来保持对该Activity的rootView
引用。这样就可以不用每次启动Activity都去读取并渲染View了。但View attach到我们的Window上,就会持有一个Context(即Activity)的引用。而我们的View有事一个静态变量,所以导致Activity不被回收。
解决办法: 在使用静态View时,需要确保在资源回收时,将静态View detach掉。
3)Handler:在Activity中定义Handler对象,那么Handler持有Activty
的引用。而每个Message对象是持有Handler的引用的(Message对象的target属性持有Handler引用),从而导致Message间接引用到了Activity。如果在Activty destroy
之后,消息队列中还有Message对象,Activty
是不会被回收的。
解决办法: 将Handler放入单独的类或者将Handler放入到静态内部类中(静态内部类不会持有外部类的引用)。如果想要在handler内部去调用所在的外部类Activity,可以在handler内部使用弱引用的方式指向所在Activity,在onDestory
时,调用相应的方法移除回调和删除消息。
4)监听器(各种需要注册的Listener,Watcher等):当我们需要使用系统服务时,比如执行某些后台任务、为硬件访问提供接口等等系统服务。我们需要把自己注册到服务的监听器中。然而,这会让服务持有 activity 的引用,如果程序员忘记在 activity 销毁时取消注册,那就会导致 activity 泄漏了。
解决办法:在onDestory
中移除注册
5)资源对象没关闭造成内存泄漏:当我们打开资源时,一般都会使用缓存。比如读写文件资源、打开数据库资源、使用Bitmap资源等等。当我们不再使用时,应该关闭它们,使得缓存内存区域及时回收。
解决办法:使用try finally结合,在try块中打开资源,在finally中关闭资源
6)属性动画:在使用ValueAnimator
或者ObjectAnimator
时,如果没有及时做cancel取消动画,就可能造成内存泄露。因为在cancel方法里,最后调用了endAnimation()
; ,在endAnimation
里,有个AnimationHandler
的单例,会持有属性动画对象的引用。
解决办法:在onDestory
中调用动画的cancel方法
7)RxJava
:在使用RxJava
时,如果在发布了一个订阅后,由于没有及时取消,导致Activity
/Fragment
无法销毁,导致的内存泄露。
解决办法:使用RxLifeCycle
28.内存泄漏和内存溢出区别?
(1)内存泄漏
1)内存泄漏:指程序中已动态分配的堆内存由于某种原因未释放或无法释放,造成系统内存的浪费,导致程序运行速度减慢甚至系统奔溃等严重后果。
2)一次内存泄漏似乎不会有大的影响,但内存泄漏后堆积的结果就是内存溢出。
3)内存泄漏具有隐蔽性,积累性的特征,比其他内存非法访问错误更难检测。这是因为内存泄漏产生的原因是内存块未被释放,属于遗漏型缺陷而不是过错型缺陷。此外,内存泄漏不会直接产生可观察的错误,而是逐渐积累,降低系统的整体性性能。
如何做好面试突击,规划学习方向?
面试题集可以帮助你查漏补缺,有方向有针对性的学习,为之后进大厂做准备。但是如果你仅仅是看一遍,而不去学习和深究。那么这份面试题对你的帮助会很有限。最终还是要靠资深技术水平说话。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。建议先制定学习计划,根据学习计划把知识点关联起来,形成一个系统化的知识体系。
学习方向很容易规划,但是如果只通过碎片化的学习,对自己的提升是很慢的。
我们搜集整理过这几年字节跳动,以及腾讯,阿里,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。
我们在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注Android)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
3446935563)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!