• Java实习生常规技术面试题每日十题Java基础(五)


    目录

    1.启动一个线程是用run()还是start()? .?

    2.线程的基本状态以及状态之间的关系。

    3.Set和List的区别,List和Map的区别?

    4.同步方法、同步代码块区别?

    5.描述Java 锁机制。

    6.Comparable和Comparator接口是干什么的?列出它们的区别

    7.Java集合类框架的最佳实践有哪些?

    8.HashMap和Hashtable的区别。

    9.HashSet和TreeSet有什么区别?

    10.说出ArrayList,Vector, LinkedList的存储性能和特性。


    1.启动一个线程是用run()还是start() .

    启动一个线程是调用start()方法,使线程就绪状态,以后可以被调度为运行状态,一个线程必须关联一些具体的执行代码,run()方法是该线程所关联的执行代码。

    2.线程的基本状态以及状态之间的关系。

    1、新建状态(New):新创建了一个线程对象。

    2、就绪状态(Runnable):也叫可运行状态。线程对象创建后,其他线程调用了该对象的start()方法。该状态的线程位于可运行线程池中,变得可运行,等待获取CPU的使用权。

    3、运行状态(Running):就绪状态的线程获取了CPU,执行程序代码。

    4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的情况分三种:

    **①等待阻塞:**运行的线程执行wait()方法,JVM会把该线程放入等待池中。

    **②同步阻塞:**运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中。

    **③其他阻塞:**运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

    5、死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

    3.Set和List的区别,List和Map的区别?

    1、Set是无序的,元素不可重复;List是有序的,元素可以重复;

    2、List存储的是单个对象的集合(有序的),Map存储的是键值对为对象的集合(无序的);

    4.同步方法、同步代码块区别?

    1.同步方法

    即有synchronized关键字修饰的方法。

    由于java的每个对象都有一个内置锁,当用此关键字修饰方法时,

    内置锁会保护整个方法。在调用该方法前,需要获得内置锁,否则就处于阻塞状态。

    2.同步代码块

    即有synchronized关键字修饰的语句块。

    被该关键字修饰的语句块会自动被加上内置锁,从而实现同步

    5.描述Java 锁机制。

    java中所说的锁就是指的内置锁,每个java对象都可以作为一个实现同步的锁,虽然说在java中一切皆对象, 但是锁必须是引用类型的,基本数据类型则不可以 。每一个引用类型的对象都可以隐式的扮演一个用于同步的锁的角色,执行线程进入synchronized块之前会自动获得锁,无论是通过正常语句退出还是执行过程中抛出了异常,线程都会在放弃对synchronized块的控制时自动释放锁。 获得锁的唯一途径就是进入这个内部锁保护的同步块或方法 。

    6.Comparable和Comparator接口是干什么的?列出它们的区别

    它们都是用于对类的对象进行比较和排序使用的接口。

    Comparable是排序接口,位于java.lang包下,若一个类实现了Comparable接口,且重写了compareTo方法,就意味着该类支持排序,常结合Collections.sort或Arrays.sort对集合或数组内的元素进行排序。

    Comparator是比较接口,位于java.util包下,我们如果需要控制某个类对象的次序,而该类本身不支持排序(即没有实现Comparable接口),那么我们就可以建立一个“该类的比较器”来进行排序,这个“比较器”只需要实现Comparator接口即可。

    Comparable相当于“内部比较器”,而Comparator相当于“外部比较器”。

    7.Java集合类框架的最佳实践有哪些?

    首先Java中的集合框架体系非常强大和完善,主要用于程序中的数据存储,从最顶层主要分为了Collection和Map接口,我们平时使用的集合类都是从这两个类别中扩展开来,正确选择要使用的集合的类型对性能非常重要。

    比如:

    1)元素的大小是固定的,而且能事先知道,我们就应该用Array而不是ArrayList。

    2)如果我们大概知道存储的数量,可以在使用集合时先给予一个初始容量大小,从而有效避免集合自动增长的算法而造成的空间浪费,如new ArrayList(30)。

    3)为了类型安全,提高存取效率和可读性,我们优先使用泛型,并且还能有效避免ClassCastException类型转换异常。

    4)有时为了提高数据的快速定位查找,可优先使用Map键值对集合,因为Map集合在数据的查找上效率非常高,但是如果要保证数据的顺序,最好使用List

    5)使用JDK提供的不变类作为Map的键可以避免为我们自己的类实现hashCode()和equals()方法。

    6)底层的集合实际上是空的情况下,返回长度是0的集合或者是数组,不要返回null。

    8.HashMap和Hashtable的区别。

    1、HashMap和HashTable都是键值对数据结构,且都实现了Map接口,存储的元素无序;

    2、HashMap非线程安全的,而HashTable是线程安全的(HashTable里面的方法使用Synchronize关键字修饰),所以HashMap的效率高于HashTable。

    3、HashMap允许空键空值,HashTable则不允许

    9.HashSet和TreeSet有什么区别?

    相同点:1、单列存储 2、元素不可重复

    不同点:1、底层数据结构不同(HashSet=哈希表结构 TreeSet=二叉树结构)

    2、数据唯一性依据不同(HashSet通过重写hashcode和equals TreeSet通过compareable接口)

    3、有序性不同,HashSet无序,TreeSet有序

    10.说出ArrayList,Vector, LinkedList的存储性能和特性。

    1、ArrayList和LinkedList、Vector都实现了List接口;

    2、ArrayList和Vector底层是用数组实现的,而LinkedList使用双向链表实现的,在集合插入、删除元素时,ArrayList需要移动数组元素性能较差;但是在查询时,因为是连续的数组,所以查询速度快;LinkedList正好相反。

    3、在容量增长上,ArrayList增长原来50%,Vector集合增加容量原来的一倍。

    4、安全性方面Vector能够保证线程安全,但是效率比ArrayList要低。

    其他面试题:

    Java实习生常规技术面试题每日十题Java基础(八)

    Java实习生常规技术面试题每日十题Java基础(七)

    Java实习生常规技术面试题每日十题Java基础(六)

    Java实习生常规技术面试题每日十题Java基础(五)

    Java实习生常规技术面试题每日十题Java基础(四)

    Java实习生常规技术面试题每日十题Java基础(三)

    Java实习生常规技术面试题每日十题Java基础(二)

    Java实习生常规技术面试题每日十题Java基础(一)

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    js打印99乘法表
    网络安全(黑客)自学
    天天被开发怼?4个方法区分bug前后端归属,我再也不背锅了!
    直接激光雷达里程计:基于稠密点云的快速定位
    Android开发基础——常用控件的使用方法
    MySQL——慢查询日志分析
    保证Redis和数据库数据一致性的方法
    ORB-SLAM2 ---- ORBextractor::operator()仿函数
    02.从0到1,软件基础平台供应商技术团队建设例程
    Java设计模式解析:工厂模式和策略模式的使用场景
  • 原文地址:https://blog.csdn.net/drhrht/article/details/126106715