Android&Java面试题大全—金九银十面试必备【上(1),讲的太清楚了

Java 中类加载分为 3 个步骤:加载、链接、初始化。

1.加载。

加载是将字节码数据从不同的数据源读取到JVM内存,并映射为 JVM 认可的数据结构,也就是 Class 对象的过程。数据源可以是 Jar 文件、Class 文件等等。如果数据的格式并不是 ClassFile 的结构,则会报 ClassFormatError。

2.链接。

链接是类加载的核心部分,这一步分为 3 个步骤:验证、准备、解析。
验证。 验证是保证JVM安全的重要步骤。JVM需要校验字节信息是否符合规范,避免恶意信息和不规范数据危害JVM运行安全。如果验证出错,则会报VerifyError。
准备。 这一步会创建静态变量,并为静态变量开辟内存空间。
解析。 这一步会将符号引用替换为直接引用

3.初始化。

初始化会为静态变量赋值,并执行静态代码块中的逻辑。

双亲委派模型

类加载器大致分为3类:启动类加载器、扩展类加载器、应用程序类加载器。
1.启动类加载器主要加载 jre/lib下的jar文件。
2.扩展类加载器主要加载 jre/lib/ext 下的jar文件。
3.应用程序类加载器主要加载 classpath 下的文件
所谓的双亲委派模型就是当加载一个类时,会优先使用父类加载器加载,当父类加载器无法加载时才会使用子类加载器去加载。这么做的目的是为了避免类的重复加载。

Java 中的集合类

HashMap 的原理

HashMap 的内部可以看做数组+链表的复合结构。数组被分为一个个的桶(bucket)。哈希值决定了键值对在数组中的寻址。具有相同哈希值的键值对会组成链表。需要注意的是当链表长度超过阈值(默认是8)的时候会触发树化,链表会变成树形结构。

把握HashMap的原理需要关注4个方法:hash、put、get、resize。

1.hash方法。

将 key 的 hashCode 值的高位数据移位到低位进行异或运算。这么做的原因是有些 key 的 hashCode 值的差异集中在高位,而哈希寻址是忽略容量以上高位的,这种做法可以有效避免哈希冲突。

2.put 方法。

put 方法主要有以下几个步骤
①通过 hash 方法获取 hash 值,根据 hash 值寻址
②如果未发生碰撞,直接放到桶中。
③如果发生碰撞,则以链表形式放在桶后
④当链表长度大于阈值后会触发树化,将链表转换为红黑树。
⑤如果数组长度达到阈值,会调用 resize 方法扩展容量。

3.get方法。

get 方法主要有以下几个步骤:
①通过 hash 方法获取 hash 值,根据 hash 值寻址。
②如果与寻址到桶的 key 相等,直接返回对应的 value
③如果发生冲突,分两种情况。如果是树,则调用 getTreeNode 获取 value;如果是链表则通过循环遍历查找对应的 value。

4.resize 方法。 resize 做了两件事:

①将原数组扩展为原来的 2 倍
②重新计算 index 索引值,将原节点重新放到新的数组中。这一步可以将原先冲突的节点分散到新的桶中

sleep 和 wait 的区别

①sleep 方法是 Thread 类中的静态方法,wait 是 Object 类中的方法

结尾

我还总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料,免费分享给大家。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

领取方式:关注+点赞+点击我的GitHub 免费获取

5%E6%8B%BF%E9%AB%98%E8%96%AA%EF%BC%81.md)!**

image

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
金九银是指每年的9月和10月,是求职市场的旺季,也是一年中最好的就业季节。在这个时期,很多公司都会开展招聘活动,包括Java开发岗位。因此,准备一些Java面试题是非常有必要的。根据引用所提到的Java面试题大全,这套面试题被分为六个模块,分别是Java基础面试题、多线程面试题、Redis面试题、数据结构与算法、Java异常面试题和JVM面试题。其中,Java基础面试题涵盖了Java语言的基本知识,多线程面试题关注多线程编程的相关概念和技巧,Redis面试题则涉及到对Redis的理解和使用,数据结构与算法模块考察算法思维和数据结构的应用,Java异常面试题关注Java异常处理机制,而JVM面试题则着重于Java虚拟机的原理和性能调优等方面的知识。由于篇幅限制,无法一一展示所有的面试题,但可以通过引用和引用中提供的方式获取更多的Java面试题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [2020 年 Java 面试题集锦(金九银)](https://blog.csdn.net/qq_41770757/article/details/107900873)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [精选2020年大厂高频Java面试真题集锦(含答案),面试一路开挂](https://blog.csdn.net/QAQFyl/article/details/108028787)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值