JAVA简答(二)

15 . Java集合类框架的基本接口有哪些?

image.png

  1. 什么是迭代器(Iterator)?
  • 定义:迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象。
  • Iterator和ListIterator的区别:
    (一). Iterator可用来遍历Set和List集合,但是ListIterator只能用来遍历List。
    (二). Iterator对集合只能是前向遍历,ListIterator既可以前向也可以后向
    (三). ListIterator实现了Iterator接口,并包含其他的功能,比如:增加元素,替换元素,获取前一个和后一个元素的索引等等。
  • 快速失败(fail-fast)和安全失败(fail-safe)的区别
    (一). 快速失败(fail—fast):在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(增加、删除、修改),则会抛出Concurrent Modification Exception。
    (二). 安全失败(fail—safe):采用安全失败机制的集合容器,在遍历时不是直接在集合内容上访问的,而是先复制原有集合内容,在拷贝的集合上进行遍历
  1. HashMap和Hashtable有什么区别?
  • HashMap是非线程安全的,HashTable是线程安全的,HashMap效率比HashTable的要高。
  • HashMap的键和值都允许有null值存在(一个key为null,多个value为null),而HashTable则不行。
  • Hashtable是同步的,而HashMap不是。因此,HashMap更适合于单线程环境,而Hashtable适合于多线程环境。
  • HashMap提供了可供应用迭代的键的集合,因此,HashMap是快速失败的。另一方面,Hashtable提供了对键的列举(Enumeration)。
  • 一般现在不建议用HashTable, ①是HashTable是遗留类,内部实现很多没优化和冗余。②即使在多线程环境下,现在也有同步的ConcurrentHashMap替代,没有必要因为是多线程而用HashTable。
  1. hashCode()和equals()方法的重要性?
    hashCode()和equals()方法组合在一起确定元素的唯一性,当重写equals方法时,必须重写hashCode。
    比较两个元素时,先比较hashcode,如果hashcode不同,则元素一定不相等;如果相同,再用equals判断。

  2. 数组(Array)、列表(ArrayList)和LinkedList有什么区别?
    Array & ArrayList:

  • Array可以包含基本类型和对象类型,ArrayList只能包含对象类型。
  • Array空间大小是固定的,ArrayList空间是动态增长的。
    ArrayList如果空间不够,它会创建一个空间比原空间大一倍的新数组,然后将所有元素复制到新数组中,接着抛弃旧数组。

ArrayList & LinkedList:

  • ArrayList是基于数组实现的,LinkedList是基于链表
  • ArrayList适合查找,LinkedList,适合增删
  • LinkedList比ArrayList占用更大的内存,因为Linkedlist为每个节点存储俩个引用
  1. 什么是Java优先级队列(Priority Queue)?
    优先级队列采用了小根堆,元素可以按照任意的顺序插入,却总是按照排序的顺序进行检索。无论何时调用remove方法,总会获得当前优先级队列中的最小元素,但并不是对所有元素都排序。
  • 基于优先级堆
  • 不允许null值
  • 线程不安全
  • 出入队时间复杂度O(log(n))
  • 调用 remove()返回堆内最小值
  1. Enumeration接口和Iterator接口的区别?
  • 枚举占用内存少,速度快,但是不是快速失败的,所以线程不安全
  • 迭代器不允许别的线程修改正在遍历的集合,所以更安全。迭代器拥有一个修改集合底层元素得方法remove
  1. Java中垃圾回收
  • 目的:识别并且丢弃应用不再使用的对象来释放和重用资源。

  • 触发条件:
    (一).当应用程序空闲时,即没有应用线程在运行时,GC会被调用。
    (二).Java堆内存不足时,GC会被调用。

  • 回收对象:当一个对象到GC Roots不可达时,在下一个垃圾回收周期中尝试回收该对象;如果该对象重写了finalize()方法,并在这个方法中成功自救(将自身赋予某个引用),那么这个对象不会被回收。但如果这个对象没有重写finalize()方法或者已经执行过这个方法,也自救失败,该对象将会被回收。

  • 指令
    (一).System.gc()Runtime.gc()提示JVM要进行垃圾回收
    (二).finalize()
    ① 对垃圾回收器不能处理的特殊情况进行清理
    ② 也有可能使该对象重新被引用
    ③ 每个对象的finalize()方法只能被执行一次,第二次就会直接跳过finalize()方法,这就是为了防止出现对象无限复活,内存空间只增不减。

  1. Java堆的结构
    JAVA虚拟机(java8之前的划分)分为三代:年轻代(Young Generation)年老代(Old Generation)持久代(Permanent Generation)。其中持久代主要存放的是Java类的类信息,如果永久代满了或者是超过了临界值,会触发完全垃圾回收
  • 年轻代:所有新生成的对象首先都是放在年轻代的。年轻代的目标就是尽可能快速的收集掉那些生命周期短的对象。年轻代分三个区。一个Eden区,两个Survivor区(一般而言)。
  • 年老代:在年轻代中经历了N次垃圾回收后仍然存活的对象,就会被放到年老代中。因此,可以认为年老代中存放的都是一些生命周期较长的对象。
  • 持久代:用于存放静态文件,如今Java类、方法等。有些应用可能动态生成或者调用一些class,例如Hibernate 等,在这种时候需要设置一个比较大的持久代空间来存放这些运行过程中新增的类。
  1. Java中的异常
    Throwable包含了错误(Error,一般是指与虚拟机相关的问题)异常(Excetion,程序可以处理的异常)
    Exception又包含了运行时异常(RuntimeException, 又叫非检查异常)非运行时异常(又叫检查异常)
  • Error是程序无法处理的,如系统崩溃,虚拟机错误,内存空间不足,方法调用栈溢等,发生这些异常发生时, java虚拟机一般会终止线程 。
  • 运行时异常都是RuntimeException类及其子类,如 NullPointerException、IndexOutOfBoundsException等, 这些异常是不检查的异常, 是在程序运行的时候可能会发生的, 所以程序可以捕捉, 也可以不捕捉. 这些错误一般是由程序的逻辑错误引起的, 程序应该从逻辑角度去尽量避免.
  • 检查异常是运行时异常以外的异常, 也是Exception及其子类, 这些异常从程序的角度来说是必须经过捕捉检查处理的, 否则不能通过编译. 如IOException、SQLException等
  1. throw和throws有什么区别?
    语法:

throw e; //抛出异常对象
public void test throws Exception1,Exception2(){}//声明异常类型

  • Throw用于方法内部,Throws用于方法声明上
  • Throw后跟异常对象,Throws后跟异常类型
  • Throw后只能跟一个异常对象,Throws后可以一次声明多种异常类型
  1. 异常处理完成以后,Exception对象会发生什么变化?
    某个Exception异常被处理后,该对象不再被引用,gc将其标记,在下一个回收过程中被回收。

  2. 动态代理是什么
    想给实现了某个接口的类中的方法,加一些额外的处理,可以给这个类创建一个代理,就是创建一个新的类。这个代理类并不是定义好的,是动态生成的。具有解耦意义,灵活,扩展性强。比如说加日志、加事务、加权限、Spring的AOP等,都是动态代理的应用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • 集合框架: 1)特点:存储对象;长度可变;存储对象的类型可不同2)Collection(1)List:有序的;元素...
    Demo_Yang阅读 1,251评论 0 4
  • 在一个方法内部定义的变量都存储在栈中,当这个函数运行结束后,其对应的栈就会被回收,此时,在其方法体中定义的变量将不...
    Y了个J阅读 4,413评论 1 14
  • BAT 常问的 Java基础39道常见面试题 1.八种基本数据类型的大小,以及他们的封装类 2.引用数据类型 3....
    AI乔治阅读 2,443评论 0 75
  • 什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言” Java虚拟机是一个可执行Java字节码的虚拟...
    Demo_Yang阅读 840评论 0 2
  • Java 面试题 整理自牛客网 什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”? Java虚拟...
    GuaKin_Huang阅读 10,662评论 19 265