【面试系列】Java面试知识篇(五)

发布于:2022-12-19 ⋅ 阅读:(289) ⋅ 点赞:(0)

在这里插入图片描述
个人简介:

📦个人主页:赵四司机
🏆学习方向:JAVA后端开发
📣种一棵树最好的时间是十年前,其次是现在!
🔔博主推荐网站:牛客网 刷题|面试|找工作神器
💖喜欢的话麻烦点点关注喔,你们的支持是我的最大动力。

前言

由于很快到了金九银十的秋招季节,博主最近也在找一些面经资源,但是发现很多都不全,后来我发现了牛客网这个网站,发现里面不仅可以看面经,还能刷题模拟面试,要是你要找各种招聘信息也可以在上面找到,我愿称之为程序员必备网站,下面把它推荐给你们!
链接地址:牛客网

在这里插入图片描述

41.Exception和Error有什么区别

在Java中,所有异常类都有一个共同的祖先(java.lang包下的Throwable)类。Throwable下又有两个重要的子类:

  • Exception:程序本身可以处理的异常,可以通过catch进行捕获,而Exception又可以分为Checked Exception(受检查异常,必须处理)和Uchecked Exception(不受异常检查,可以不处理)。
  • Error:Error属于程序无法处理的错误,例如Java虚拟机运行错误、虚拟机内存不足、类定义错误等。这些异常发生时,Java虚拟机一般会选择线程终止。

42.Checked Exception和Uchecked Exception有什么区别

  • Checked Exception:即受检查异常,Java代码在编译过程中,如果异常没有被catch或者throws关键字处理就没法通过编译。除了Runtime Exception及其子类之外,其他的Exception类及其子类都属于受检查异常,常见的受检查异常有:IO相关的异常、ClassNotFoundException、SQLException…
  • Unchecked Exception:不受检查的异常,Java代码在编译过程中,我们即使不检查不受检查异常代码也能通过编译,RuntimeException及其子类都统称为非受检查异常,常见的有:
    • NullPointerException(空指针异常)
    • IllegalArgumentException(参数错误比如方法入参类型错误)
    • NumberFormatException(字符串转换为数字格式错误,IlleglArgumentException的子类)
    • ArrayIndexOutOfBoundsException(数组越界错误)
    • ClassCastException(类型转换错误)
    • ArithmeticException(算术错误)
    • SecurityException(安全错误比如权限不够)
    • UnsupportedOperationException(不支持的操作错误比如重复操作同一用户)

43.Throwable类常用方法有哪些

  • String getMessage():返回异常发生时候的简要信息
  • String toString():返回异常发生时的详细信息
  • String getLocalizedMessage():返回异常对象的本地化信息,使用Throwable的子类覆盖这个方法,可以生成本地化信息。如果子类没有覆盖该方法,则该方法返回信息与getMessage()返回结果相同。
  • void printStackTrace():在控制台上打印Throwable对象封装的信息。

44.try-catch-finally如何使用

  • try块:用于异常捕获,其后可接0个或多个catch块,如果没有catch块,则必须跟一个finally块。
  • catch块:用于处理try捕获到的异常。
  • finally块:无论是否捕获或处理异常,finally块里的语句都会被执行,当在try块或者catch块中遇到return语句时候,finally语句块将在在方法返回之前执行。
  • 注意:不要在finally块中使用return语句,因为当try和finally语句块中都有return语句时候,try语句块中的return语句会被忽略,这是因为try语句块中的return返回值会被暂存到一个本地变量中,当执行到fianlly语句的return之后,这个本地变量的值就会变成finally语句块中return的返回值。

45.Finally块中代码一定会被执行吗

不一定,以下情况不会被执行:

  • finally之前虚拟机被终止
  • 程序所在线程死亡
  • 关闭CPU

46.try-with-resources用法

try (BufferedInputStream bin = new BufferedInputStream(new FileInputStream(new File("test.txt")));
     BufferedOutputStream bout = new BufferedOutputStream(new FileOutputStream(new File("out.txt")))) {
    int b;
    while ((b = bin.read()) != -1) {
        bout.write(b);
    }
}
catch (IOException e) {
    e.printStackTrace();
}

面对必须要关闭的资源,我们总是应该优先使用try-with-resources而不是try-finally。随着产生的代码更短更简洁,产生的异常信息也对我们更有用。try-withresources语句让我们更容易编写必须要关闭的资源的代码,若采用try-finally则几乎做不到这点。

47.什么是泛型,有什么作用

Java泛型是JDK5引入的一个新特性,使用泛型可以增加代码的可读性以及稳定性,编译器可以对泛性参数进行检测,并且通过泛型参数可以指定传入的对象类型。

泛型一般有三种使用方式:泛型类、泛型接口、泛型方法

  • 泛型类:

    public public class Generic<T>{
        private T t;
    
        public T get(){
            return t;
        }
    
        public void set(T t){
            this.t = t;
        }
    }
    
  • 泛型方法:

    public T show(T t){

    return t;

    }

  • 泛型接口:

    public interface GenInterface<T> {
        void show(T t);
    }
    
    public class GenImpl<T> implements GenInterface<T>{
        @Override
        public void show(T t) {
            System.out.println(t);
        }
    }
    
    public class CollectionDemo{
    
        public static void main(String[] args) {
            GenImpl<String> str = new GenImpl<String>();
            str.show("加油");
    
            GenImpl<Integer> i = new GenImpl<>();
            i.show(30);
        }
    }
    

类型擦除

泛型信息只存在于编译阶段,在进入JVM之前,与泛型相关的信息都会被擦除掉,专业术语叫类型擦除,通俗讲泛型类和普通类在JVM中并没有什么不同,当泛型类进入JVM之后,如果泛型类中泛型参数没有指定上限,则其泛型会被转译为Object类型,如果指定了上限就会被转译成类型上限。

泛型由于有类型擦除的存在,会存在一定的局限性,我们可以通过反射机制来绕过泛型限制,存在一定的安全性问题。

但是正由于有类型擦除的存在,才能兼容以前版本的Java代码。

温馨提示:上面只是我总结的面经知识,如果你想要更全面的可以到网站自行查看喔。
友情链接:牛客网
在这里插入图片描述


网站公告

今日签到

点亮在社区的每一天
去签到