java面试题(java中高级面试题及答案)

[java面试题]

1.Collections.sort排序内部原理
Java6Arrays.sort()和Collections.sort()中使用MergeSort,在Java7中,内部实现被TimSort代替,这需要对对象之间的比较进行更严格的实现
2.HashMap原理,java8所做的更改
在结构实现方面,HashMap是通过数组+链表+红黑树(JDK1.8添加了红黑树部分)实现的。HashMap仅允许一个记录的键最多为空,而允许多个记录的值为空。HashMap不是线程安全的。ConcurrentHashMap是线程安全的。解决冲突:发生冲突时,请使用zipper方法在单链接列表中链接其关键字为同义词的节点。哈希表的长度为m,定义了一个由m个头指针组成的指针数组T,并将地址为i的节点插入到以T(i)作为头指针的单链表中。在Java8中,冲突元素超出了限制(8),并且链表被一棵红黑树取代。
3.String和StringBuilder之间的区别
1)可变且不可变:字符串不可变,并且每次执行“+”时都会生成一个新对象。因此,在频繁更改字符串以节省内存的情况下,不使用String。
2)是否是多线程安全的:StringBuilder不会向该方法添加同步锁,因此它不是线程安全的。StringBuffer和String都是线程安全的。
4.向量和数组的区别
1)当内存不足时࿰

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
海尔高级Java面试主要考察Java基础、多线程、集合、IO、反射等知识点。以下是部分目及答案整理: 1、Java中的四种引用类型分别是什么,有什么区别? 答:Java中的四种引用类型分别是强引用、软引用、弱引用和虚引用。它们的主要区别在于对对象的引用强度不同。强引用是最常见的引用方式,它能够直接引用对象,只有在没有任何引用的情况下才会被垃圾回收器回收。软引用和弱引用都比强引用弱,但是又有所不同。软引用在系统要发生内存溢出之前会被回收,弱引用则更弱,只要发现就会被回收,虚引用最弱,它的存在不会对对象的生命周期造成任何影响,主要用于跟踪对象被垃圾回收的状态。 2、请简述Java内存模型,并解释volatile关键字的作用。 答:Java内存模型可以看成一个虚拟的概念模型,主要包括线程工作内存和主内存两个部分。线程工作内存是线程独立的内存空间,主内存是被所有线程共享的内存空间。volatile关键字可以保证线程之间对变量的可见性,即一个线程修改了volatile变量,其他线程能够立即看到这个变量的改变,而在Java的内存模型中,由于线程之间的数据交互是通过主内存来完成的,所以volatile变量修改后会立即被更新到主内存中,其他线程能够立即看到最新变量。 3、请解释HashMap的实现原理。 答:HashMap是一种散列表,它包含一个数组和一些列链表。散列表的存储结构是一个数组,数组中每一个元素称为桶(Bucket),桶是一个链表结构,表示一组映射到相同桶的键值对。HashMap的实现原理是通过hashCode算法将键值对映射为数组的下标,然后将键值对存储在桶中。如果两个键映射到同一个桶中,那么它们会以链表的方式存储在桶中。当查找一个键值对时,HashMap会根据键的hashCode值计算出它存储的桶的下标,然后在该桶中查找对应的键值对。如果桶中存在多个键值对,则需要遍历链表,查找对应的键值对。 除了以上目,海尔高级Java面试还包括Java注解、类加载器、反射等主,需要面试者充分掌握Java基础知识,具备实战经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值