【面试系列】Java面试知识篇(五)_error (46, 44) java -source 8 中不支持 try-with-resou

本文介绍了Java中的异常处理机制(try-catch-finally),finally块的执行规则,以及try-with-resources的便捷用法。同时,对Java泛型进行了概述,包括其作用、使用场景和类型擦除的概念。
摘要由CSDN通过智能技术生成
  • 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代码。

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

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

bbs.csdn.net/topics/618545628)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值