Java面试题之四

 十六、运行时异常与一般异常有何异同

Java提供了两类主要的异常:runtime exception和checked exception。

1.checked exception:这种异常也就是我们经常遇到的IO异常,以及SQL异常等。对于这种异常,JAVA编译器强制要求我们必须进行catch。所以,面对这种异常不管我们是否愿意,只能自己去写一大堆catch块去处理可能的异常。

2. runtime exception:也称运行时异常,是最常见的异常之一,不是必须处理的异常,比如:我们从来没有人去处理过NullPointerException异常。当出现这样的异常时,总是由虚拟机接管,系统会把异常一直往上层抛,直到遇到处理代码。如果没有处理代码,要么是线程中止,要么是主程序终止。

十七、ArrayList和Vector的区别,HashMap和Hashtable的区别?

ArrayList和Vector:

1.同步性:Vector 线程安全,同步;ArrayList线程不安全,不同步。

2.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半。

HashMap和Hashtable:

1.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现类。

2.同步性:Hashtable线程安全,同步;HashMap线程不安全,不同步。

3.值:HashMap允许空键控值。Hashtable不允许。

十八、LinkedList和ArrayList的区别?

1. LinkedList是基于链表实现;ArrayList是基于动态数组实现。

2.对于随机访问,ArrayList优于LinkedList。因为LinkedList要移动指针。

3.对于新增和删除操作,总体来说LinkedList要优于ArrayList。但并不是所有情况都优于ArrayList。比如,插入和删除单条数据和在末尾插入和删除数据ArrayList反而优于LinkedList。

所以综合来说,随机访问比较多就用ArrayList。频繁插入和删除比较多就用LinkedList。

十九、介绍JAVA开发中常用的Collection Frame Work(集合框架)?

Java中集合框架分为CollectionMap接口,Collection接口下的集合每个元素都由一个值组成,Map接口下的集合类每个元素都是由键值对组成。
1.Collection接口下面有ListSet接口,List接口下常见的实现类有ArrayList、LinkedList、Vector。它们中的元素可以重复,并且是有序的。Set接口下常见的实现类有HashSet、TreeSet。它们中的元素不能重复,并且是无序的。

2.Map接口下常见的实现类有:HashMapTreeMap。注意Hashtable和HashMap非常类似,但它是Dictionary的子类。

二十、在异常当中 throw和throws 有什么区别和联系?

1. throws 是方法修饰符,表示该方法有可能抛出某个异常,这时调用方就必须处理该异常。谁调用谁捕获。throw是关键字,表示显示抛出异常对象。

2. throws可单独使用。throw要么和try-catch-finally语句配套使用,要么与throws配套使用。

3. throws用在方法声明后,throw用在方法体内。

4. throws抛出的是类;throw抛出的是对象。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

u010142437

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

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

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

打赏作者

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

抵扣说明:

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

余额充值