【金三银四】我的头条面试经历分享,含BATJM大厂

【金三银四】我的头条面试经历分享,含BATJM大厂,第1张

概述一.开发背景想要成为一名优秀的Android开发,你需要一份完备的知识体系,在这里,让我们一起成长为自己所想的那样。一、Android基础Android基础知识点比较多,看图。建议阅读:《Android开发艺术探索》1.Activity#Activity的四大启动模式,以及应用场景?Activity的四大启 一. 开发背景

想要成为一名优秀的AndroID开发,你需要一份完备的知识体系,在这里,让我们一起成长为自己所想的那样。

一、AndroID基础

AndroID基础知识点比较多,看图。

建议阅读:

《AndroID开发艺术探索》

1. Activity# Activity的四大启动模式,以及应用场景?

@H_502_32@Activity的四大启动模式:

@H_502_32@standard:标准模式,每次都会在活动栈中生成一个新的@H_502_32@Activity实例。通常我们使用的活动都是标准模式。@H_502_32@singletop:栈顶复用,如果@H_502_32@Activity实例已经存在栈顶,那么就不会在活动栈中创建新的实例。比较常见的场景就是给通知跳转的@H_502_32@Activity设置,因为你肯定不想前台@H_502_32@Activity已经是该@H_502_32@Activity的情况下,点击通知,又给你再创建一个同样的@H_502_32@Activity。@H_502_32@singleTask:栈内复用,如果@H_502_32@Activity实例在当前栈中已经存在,就会将当前@H_502_32@Activity实例上面的其他@H_502_32@Activity实例都移除栈。常见于跳转到主界面。@H_502_32@singleInstance:单实例模式,创建一个新的任务栈,这个活动实例独自处在这个活动栈中。# Activity中onStart和onResume的区别?onPause和onStop的区别?

首先,@H_502_32@Activity有三类:

前台@H_502_32@Activity:活跃的@H_502_32@Activity,正在和用户交互的@H_502_32@Activity。可见但非前台的@H_502_32@Activity:常见于栈顶的@H_502_32@Activity背景透明,处在其下面的@H_502_32@Activity就是可见但是不可和用户交互。后台@H_502_32@Activity:已经被暂停的@H_502_32@Activity,比如已经执行了@H_502_32@onStop方法。

所以,@H_502_32@onStart和@H_502_32@onStop通常指的是当前活动是否位于前台这个角度,而@H_502_32@onResume和@H_502_32@onPause从是否可见这个角度来讲的。

2. 屏幕适配# 平时如何有使用屏幕适配吗?原理是什么呢?

平时的屏幕适配一般采用的头条的屏幕适配方案。简单来说,以屏幕的一边作为适配,通常是宽。

原理:设备像素@H_502_32@px和设备独立像素@H_502_32@dp之间的关系是

@H_502_32@px = dp * density

假设UI给的设计图屏幕宽度基于360dp,那么设备宽的像素点已知,即px,dp也已知,360dp,所以@H_502_32@density = px / dp,之后根据这个修改系统中跟@H_502_32@density相关的知识点即可。

3. AndroID消息机制# AndroID消息机制介绍?

AndroID消息机制中的四大概念:

@H_502_32@ThreadLocal:当前线程存储的数据仅能从当前线程取出。@H_502_32@MessageQueue:具有时间优先级的消息队列。@H_502_32@Looper:轮询消息队列,看是否有新的消息到来。@H_502_32@Handler:具体处理逻辑的地方。

过程:

准备工作:创建@H_502_32@Handler,如果是在子线程中创建,还需要调用@H_502_32@Looper#prepare(),在@H_502_32@Handler的构造函数中,会绑定其中的@H_502_32@Looper和@H_502_32@MessageQueue。发送消息:创建消息,使用@H_502_32@Handler发送。进入@H_502_32@MessageQueue:因为@H_502_32@Handler中绑定着消息队列,所以@H_502_32@Message很自然的被放进消息队列。@H_502_32@Looper轮询消息队列:@H_502_32@Looper是一个死循环,一直观察有没有新的消息到来,之后从@H_502_32@Message取出绑定的@H_502_32@Handler,最后调用@H_502_32@Handler中的处理逻辑,这一切都发生在@H_502_32@Looper循环的线程,这也是@H_502_32@Handler能够在指定线程处理任务的原因。# Looper在主线程中死循环为什么没有导致界面的卡死?导致卡死的是在Ui线程中执行耗时 *** 作导致界面出现掉帧,甚至@H_502_32@ANR,@[email protected]()这个 *** 作本身不会导致这个情况。有人可能会说,我在点击事件中设置死循环会导致界面卡死,同样都是死循环,不都一样的吗?Looper会在没有消息的时候阻塞当前线程,释放cpu资源,等到有消息到来的时候,再唤醒主线程。App进程中是需要死循环的,如果循环结束的话,App进程就结束了。# IDleHandler介绍?

介绍: IDleHandler是在Hanlder空闲时处理空闲任务的一种机制。

执行场景:

@H_502_32@MessageQueue没有消息,队列为空的时候。@H_502_32@MessageQueue属于延迟消息,当前没有消息执行的时候。

会不会发生死循环: 答案是否定的,@H_502_32@MessageQueue使用计数的方法保证一次调用@H_502_32@MessageQueue#next方法只会使用一次的@H_502_32@IDleHandler集合。

4. VIEw事件分发机制和VIEw绘制原理

刚哥的《AndroID开发艺术探索》已经很全面了,建议阅读。

5. Bitmap# Bitmap的内存计算方式?

在已知图片的长和宽的像素的情况下,影响内存大小的因素会有资源文件位置和像素点大小。

像素点大小: 常见的像素点有:

ARGB_8888:4个字节ARGB_4444、ARGB_565:2个字节

资源文件位置: 不同dpi对应存放的文件夹

比如一个一张图片的像素为@H_502_32@180*180px,@H_502_32@dpi(设备独立像素密度)为320,如果它仅仅存放在@H_502_32@drawable-hdpi,则有:

@H_502_32@横向像素点 = 180 * 320/240 + 0.5f = 240 px纵向像素点 = 180 * 320/240 + 0.5f = 240 px

如果 如果它仅仅存放在@H_502_32@drawable-xxhdpi,则有:

@H_502_32@横向像素点 = 180 * 320/480 + 0.5f = 120 px纵向像素点 = 180 * 320/480 + 0.5f = 120 px

所以,对于一张@H_502_32@180*180px的图片,设备dpi为320,资源图片仅仅存在@H_502_32@drawable-hdpi,像素点大小为@H_502_32@ARGB_4444,最后生成的文件内存大小为:

@H_502_32@横向像素点 = 180 * 320/240 + 0.5f = 240 px纵向像素点 = 180 * 320/240 + 0.5f = 240 px内存大小 = 240 * 240 * 2 = 115200byte 约等于 112.5kb
# Bitmap的高效加载?

Bitmap的高效加载在GlIDe中也用到了,思路:

获取需要的长和宽,一般获取控件的长和宽。设置@[email protected]中的@H_502_32@inJustDecodeBounds为true,可以帮助我们在不加载进内存的方式获得@H_502_32@Bitmap的长和宽。对需要的长和宽和Bitmap的长和宽进行对比,从而获得压缩比例,放入@[email protected]中的@H_502_32@inSampleSize属性。设置@[email protected]中的@H_502_32@inJustDecodeBounds为false,将图片加载进内存,进而设置到控件中。二、AndroID进阶

AndroID进阶中重点考察@H_502_32@AndroID Framework、性能优化和第三方框架。

1. Binder# Binder的介绍?与其他IPC方式的优缺点?

Binder是AndroID中特有的IPC方式,引用《AndroID开发艺术探索》中的话(略有改动):

从IPC角度来说,Binder是AndroID中的一种跨进程通信方式;Binder还可以理解为虚拟的物理设备,它的设备驱动是/dev/binder;从@H_502_32@AndroID Framework来讲,Binder是@H_502_32@Service Manager连接各种@H_502_32@Manager和对应的@H_502_32@ManagerService的桥梁。从面向对象和CS模型来讲,@H_502_32@ClIEnt通过Binder和远程的@H_502_32@Server进行通讯。

基于Binder,AndroID还实现了其他的IPC方式,比如@H_502_32@AIDL、@H_502_32@Messenger和@H_502_32@ContentProvIDer。

与其他IPC比较:

效率高:除了内存共享外,其他IPC都需要进行两次数据拷贝,而因为Binder使用内存映射的关系,仅需要一次数据拷贝。安全性好:接收方可以从数据包中获取发送发的进程ID和用户ID,方便验证发送方的身份,其他IPC想要实验只能够主动存入,但是这有可能在发送的过程中被修改。写在最后

本次我的分享也接近尾声了,感谢你们在百忙中花上一下午来这里聆听我的宣讲,希望在接下来的日子,我们共同成长,一起进步!!!

最后放上一个大概的AndroID学习方向及思路(详细的内容太多了~),提供给大家:

对于程序员来说,要学习的知识内容、技术有太多太多,这里就先放上一部分,其他的内容有机会在后面的文章向大家呈现出来,不过我自己所有的学习资料都整理成了一个文档,一直在不断学习,如今整理的资料不知不觉居然已经有将近80G了,在这里作为读者福利免费分享给大家,希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

资料获取传送门:点击免费获取Android架构设计

群内有许多技术大牛,有任何问题,欢迎广大网友一起来交流,群内还不定期免费分享高阶AndroID学习视频资料和面试资料包~

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!

AndroID架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!

AndroID架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

总结

以上是内存溢出为你收集整理的【金三银四】我的头条面试经历分享,含BATJM大厂全部内容,希望文章能够帮你解决【金三银四】我的头条面试经历分享,含BATJM大厂所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/web/1004994.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存