JAVA基础面试题汇总二

JAVA基础面试题汇总【建议收藏】

1、 Hashcode的作用

背景:

  • java的集合有两类,一类是List,还有一类是Set。前者有序可重复,后者无序不重复。当我们在set中插入的时候怎么判断是否已经存在该元素呢,可以通过equals方法。但是如果元素太多,用这样的方法就会比较慢。
  • 于是有人发明了哈希算法来提高集合中查找元素的效率。 这种方式将集合分成若干个存储区域,每个对象可以计算出一个哈希码,可以将哈希码分组,每组分别对应某个存储区域,根据一个对象的哈希码就可以确定该对象应该存储的那个区域。

理解:

  • 它返回的就是根据对象的内存地址换算出的一个值。这样一来,当集合要添加新的元素时,先调用这个元素的hashCode方法,就一下子能定位到它应该放置的物理位置上。如果这个位置上没有元素,它就可以直接存储在这个位置上,不用再进行任何比较了;如果这个位置上已经有元素了,就调用它的equals方法与新元素进行比较,相同的话就不存了,不相同就散列其它的地址。这样一来实际调用equals方法的次数就大大降低了,几乎只需要一两次。

2、Java的四种引用:强弱软虚

  • 强引用:强引用是平常中使用最多的引用,强引用在程序内存不足(OOM)的时候也不会被回收使用方式:
String str = new String("str");
System.out.println(str);
  • 软引用:软引用在程序内存不足时,会被回收,使用方式:
// 注意:wrf这个引用也是强引用,它是指向SoftReference这个对象的,
// 这里的软引用指的是指向new String("str")的引用,也就是SoftReference类中T
SoftReference<String> wrf = new SoftReference<String>(new String("str"));
  • 弱引用:弱引用就是只要JVM垃圾回收器发现了它,就会将之回收,使用方式:
WeakReference<String> wrf = new WeakReference<String>(str);

可用场景: Java源码中的 java.util.WeakHashMap 中的 key 就是使用弱引用,我的理解就是,一旦我不需要某个引用,JVM会自动帮我处理它,这样我就不需要做其它操作。

  • 虚引用:虚引用的回收机制跟弱引用差不多,但是它被回收之前,会被放入 ReferenceQueue 中。注意哦: 其它引用是被JVM回收后才被传入 ReferenceQueue 中的。由于这个机制,所以虚引用大多被用于引用销毁前的处理工作。还有就是,虚引用创建的时候,必须带有 ReferenceQueue ,
    使用例子:
PhantomReference<String> prf = new PhantomReference<String>(new String("str"),
new ReferenceQueue<>());

**可用场景:**对象销毁前的一些操作,比如说资源释放等。 Object.finalize() 虽然也可以做这
类动作,但是这个方式即不安全又低效

**注:**上诉所说的几类引用,都是指对象本身的引用,而不是指Reference的四个子类的引用(SoftReference等)。

3、泛型常用的特点

  • 泛型是Java SE 1.5之后的特性, 《Java 核心技术》中对泛型的定义是:
    “泛型” 意味着编写的代码可以被不同类型的对象所重用。
  • “泛型”,顾名思义,“泛指的类型”。我们提供了泛指的概念,但具体执行的时候却可以有具体的规则
    来约束,比如我们用的非常多的ArrayList就是个泛型类,ArrayList作为集合可以存放各种元素,如
    Integer, String,自定义的各种类型等,但在我们使用的时候通过具体的规则来约束,如我们可以约
    束集合中只存放Integer类型的元素,如
List<Integer> iniData = new ArrayList<>()

使用泛型的好处?

  • 以集合来举例,使用泛型的好处是我们不必因为添加元素类型的不同而定义不同类型的集合,如整
    型集合类,浮点型集合类,字符串集合类,我们可以定义一个集合来存放整型、浮点型,字符串型
    数据,而这并不是最重要的,因为我们只要把底层存储设置了Object即可,添加的数据全部都可向
    上转型为Object。 更重要的是我们可以通过规则按照自己的想法控制存储的数据类型。

4、有没有可能两个不相等的对象有相同的hashcode?

答案是:有可能。

  • 在产生hash冲突时,两个不相等的对象就会有相同的 hashcode 值.当hash冲突产生时,一般
    有以下几种方式来处理:
    • 拉链法:每个哈希表节点都有一个next指针,多个哈希表节点可以用next指针构成一个单向链
      表,被分配到同一个索引上的多个节点可以用这个单向链表进行存储.
    • 开放定址法:一旦发生了冲突,就去寻找下一个空的散列地址,只要散列表足够大,空的散列地址总
      能找到,并将记录存入
    • 再哈希:又叫双哈希法,有多个不同的Hash函数.当发生冲突时,使用第二个,第三个….等哈希函数
      计算地址,直到无冲突.

5、final有哪些用法?

  • final也是很多面试喜欢问的地方,但我觉得这个问题很无聊,通常能回答下以下5点就不错了:
    • 被final修饰的类不可以被继承。
    • 被final修饰的方法不可以被重写。
    • 被final修饰的变量不可以被改变.如果修饰引用,那么表示引用不可变,引用指向的内容可变。
    • 被final修饰的方法,JVM会尝试将其内联,以提高运行效率。
    • 被final修饰的常量,在编译阶段会存入常量池中。
  • 除此之外,编译器对final域要遵守的两个重排序规则更好:
    • 在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用变量,这两个操作
      之间不能重排序 初次读一个包含final域的对象的引用,与随后初次读这个final域,这两个操作之间不
      能重排序。

6、static都有哪些用法

  • 所有的人都知道static关键字这两个基本的用法:静态变量和静态方法.也就是被static所修饰的变量/方法都属于类的静态资源,类实例所共享.
  • 除了静态变量和静态方法之外,static也用于静态块,多用于初始化操作:
public calss PreCache{
 static{
 //执行相关操作
 }
}
  • 此外static也多用于修饰内部类,此时称之为静态内部类.
  • 最后一种用法就是静态导包,即 import static .import static是在JDK 1.5之后引入的新特性,可以用来指定导入某个类中的静态资源,并且不需要使用类名,可以直接使用资源名,比如:
import static java.lang.Math.*;
public class Test{
 public static void main(String[] args){
 //System.out.println(Math.sin(20));传统做法
 System.out.println(sin(20));
 }
}

7、try catch finally,try里有return,finally还执行么

执行,并且finally的执行早于try里面的return
结论:

  • 不管有木有出现异常,finally块中代码都会执行;
  • 当try和catch中有return时,finally仍然会执行;
  • finally是在return后面的表达式运算后执行的(此时并没有返回运算后的值,而是先把要返回的值保存起来,管finally中的代码怎么样,返回的值都不会改变,任然是之前保存的值),所以函数返回值是在finally执行前确定的;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员JavaWind

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值