ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

我了解到的面试的一些小内幕!持续更新中

2021-05-17 16:29:17  阅读:241  来源: 互联网

标签:px 更新 面试 Binder 240 Activity 内幕 Android 像素点


一些感悟

穷人的一次失败,为了还债可能一辈子都翻不了身,为还债一辈子送外卖。你将不再会有精力去思考和投机。穷人的失败可能断送了他所有暴富的机遇和时间,让不确定的人生瞬间确定下来,让充满无限可能的人生可能性逐渐缩小。这是赤裸裸的现实。

只有当你有足够多的资本时,允许你失误的次数才会逐渐增加。拥有足够多的资本,哪怕尝试个三番五次失败了,也不会伤你元气。所以从这个角度讲,人的机遇是随着财富的增加而增加的。这时代表面上人人机会平等,但是给穷人的机会非常有限。王思聪失败一次不过是兴趣爱好的失败,而你失败一次则是生存生活的失败。穷人,更应该不断学习和思考,因为你没有钱,知识就是你最大的财富。穷人,更应该保守,因为生活不允许你失败。

在今天记录一下我的生活。作为一个32岁的程序员,我很焦虑,我在一个不大不小的公司(讯飞),干活,日子重复无聊一晃眼7年过去了,想辞职一想到现在的年纪,房贷,车贷,孩子,家庭真的挺无奈。现在上级还时不时“透漏”公司要优化人的消息,其实还蛮焦虑的。马上35岁了要是被优化了,生活真的不知道该怎么办!

一、Android基础

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

建议阅读:

《Android开发艺术探索》

1. Activity

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

Activity的四大启动模式:

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

# Activity中onStart和onResume的区别?onPause和onStop的区别?

首先,Activity有三类:

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

所以,onStartonStop通常指的是当前活动是否位于前台这个角度,而onResumeonPause从是否可见这个角度来讲的。

2. 屏幕适配

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

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

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

px = dp * density

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

3. Android消息机制

# Android消息机制介绍?

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

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

过程:

  1. 准备工作:创建Handler,如果是在子线程中创建,还需要调用Looper#prepare(),在Handler的构造函数中,会绑定其中的LooperMessageQueue
  2. 发送消息:创建消息,使用Handler发送。
  3. 进入MessageQueue:因为Handler中绑定着消息队列,所以Message很自然的被放进消息队列。
  4. Looper轮询消息队列:Looper是一个死循环,一直观察有没有新的消息到来,之后从Message取出绑定的Handler,最后调用Handler中的处理逻辑,这一切都发生在Looper循环的线程,这也是Handler能够在指定线程处理任务的原因。

# Looper在主线程中死循环为什么没有导致界面的卡死?

  1. 导致卡死的是在Ui线程中执行耗时操作导致界面出现掉帧,甚至ANRLooper.loop()这个操作本身不会导致这个情况。
  2. 有人可能会说,我在点击事件中设置死循环会导致界面卡死,同样都是死循环,不都一样的吗?Looper会在没有消息的时候阻塞当前线程,释放CPU资源,等到有消息到来的时候,再唤醒主线程。
  3. App进程中是需要死循环的,如果循环结束的话,App进程就结束了。

# IdleHandler介绍?

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

执行场景:

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

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

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

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

5. Bitmap

# Bitmap的内存计算方式?

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

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

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

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

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

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

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

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

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

横向像素点 = 180 * 320/240 + 0.5f = 240 px
纵向像素点 = 180 * 320/240 + 0.5f = 240 px
内存大小 = 240 * 240 * 2 = 115200byte 约等于 112.5kb

# Bitmap的高效加载?

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

  1. 获取需要的长和宽,一般获取控件的长和宽。
  2. 设置BitmapFactory.Options中的inJustDecodeBounds为true,可以帮助我们在不加载进内存的方式获得Bitmap的长和宽。
  3. 对需要的长和宽和Bitmap的长和宽进行对比,从而获得压缩比例,放入BitmapFactory.Options中的inSampleSize属性。
  4. 设置BitmapFactory.Options中的inJustDecodeBounds为false,将图片加载进内存,进而设置到控件中。

二、Android进阶

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

1. Binder

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

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

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

基于Binder,Android还实现了其他的IPC方式,比如AIDLMessengerContentProvider

与其他IPC比较:

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

实战系列

话不多说,Android实战系列集合都已经系统分类好,由于文章篇幅问题没法过多展示,获取学习笔记链接:点击我的腾讯文档免费获取

实战系列

话不多说,Android实战系列集合都已经系统分类好,由于文章篇幅问题没法过多展示,获取学习笔记链接:点击我的腾讯文档免费获取

[外链图片转存中…(img-q6yztY4S-1621240066581)]

标签:px,更新,面试,Binder,240,Activity,内幕,Android,像素点
来源: https://blog.csdn.net/m0_57079235/article/details/116937870

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有