一名中级JAVA需要掌握的知识点

时光飞逝,转眼已入行三年之久,此时的心情说实话五味杂陈。

当你经历过一次工作变动,你才知道你到底是一个怎样的人,你在行业处于一个什么样地位,你有什么是让企业给你行业标准薪资又或者说高于标准薪资的能力?当你经历过这些,你才知道自己到底有几斤几两。本篇微博算是一次总结,希望在今后能够在工作中,年限在增长,经验与能力也要与之匹配。

 

基本语法:

StaticTransientforeach循环的原理,Switchjava反射机制,单线程安全类demo,常规算法等关键字作用,至少掌握其用法和场景

ExceptionError区别

Exception是程序错误,可控或不可控,可在程序中捕获异常

Error是系统异常,不可控,可能的话可在系统中捕获异常

java.util.Datejava.sql.Date的区别及应用

java.util.Date 就是在除了SQL语句的情况下面使用

java.sql.Date 是针对SQL语句使用的,它只包含日期而没有时间部分,它都有getTime方法返回毫秒数,自然就可以直接构建

java.util.Date java.sql.Date 的父类

java.util.Date d = new java.util.Date(sqlDate.getTime());

java.util.Date d=new java.util.Date (date.getTime());


集合

 一名中级JAVA需要掌握的知识点_第1张图片

一名中级JAVA需要掌握的知识点_第2张图片

 

集合的结构

其中ArrayListHashMap用到特别多,也是被问到特别多的地方

 ArrayList原理

以数组实现。节约空间,但数组有容量限制。

超出限制时会增加50%容量,用System.arraycopy()复制到新的数组,因此最好能给出数组大小的预估值。默认第一次插入元素时创建大小为10的数组。

按数组下标访问元素get(i)/set(i,e) 的性能很高,这是数组的基本优势。

直接在数组末尾加入元素add(e)的性能也高,但如果按下标插入、删除元素—add(i,e), remove(i), remove(e),则要用System.arraycopy()来移动部分受影响的元素,性能就变差了,这是基本劣势。

 

特点:

是一个相对来说比较简单的数据结构,最重要的一点就是它的自动扩容,可以认为就是我们常说的“动态数组”。

其中操作可以理解为直接将数组的内容置位,remove操作可以理解为删除index0的节点,并将后面元素移到0

 

add函数:

当我们在ArrayList中增加元素的时候,会使用add函数。他会将元素放到末尾,其实最核心的内容就是ensureCapacityInternal。这个函数其实就是自动扩容机制的核心

过程:

如果ArrayList的大小已经不满足需求时,那么就将数组变为原长度的1.5倍,之后的操作就是把老的数组拷到新的数组里面。

setget函数:

Arrayputget函数就比较简单了,先做index检查,然后执行赋值或访问操作:

remove函数:

先做index检查,然后执行删除操作

 

LinkedList原理:

Hashtable原理:

HashMap原理

HashMap基于hashing原理,我们通过put()get()方法储存和获取对象。

当我们将键值对传递给put()方法时,它调用键对象的hashCode()方法来计算hashcode,让后找到bucket位置来储存值对象。

当获取对象时,通过键对象的equals()方法找到正确的键值对,然后返回值对象。

碰撞:

HashMap使用LinkedList来解决碰撞问题,当发生碰撞了,对象将会储存在LinkedList的下一个节点中。 HashMap在每个LinkedList节点中储存键值对对象。

当两个不同的键对象的hashcode相同时会发生什么? 它们会储存在同一个bucket位置的LinkedList中。键对象的equals()方法用来找到键值对

负载因子:

默认负载因子大小0.75

map填满75%bucket时候,和其他集合类一样(ArrayList)将会创建原来HashMapda大小两倍的bucket数组

重新调整map大小,并将原来的对象放入新的bucket数组中,此过程称之为rehashing

 ConcurrentHashMap 原理:

HashSet原理:

ArrayListL‌‌inkedList的大致区别:

1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。

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

3.对于新增和删除操作addremoveLinedList比较占优势,因为ArrayList要移动数据。

 

HashMapHashTableConcurrentHashMap区别

HashMap线程不安全,HashTable线程安全,ConcurrentHashMap线程安全

HashMap的键值可以为nullHashTable不能不nullConcurrentHashMap不能为空

HashMapHashTable的轻量级实现

HashMap相比HashTable,因为HashTable是同步,ConcurrentHashMap锁分段技术

多线程场景HashMap可能会造成死循环,导致cpu利用率100%

HashTable容器是同步,会造成阻塞、轮训,ConcurrentHashMap的分布式锁,快、安全

 

集合为什么不直接实例化接口

Set set =new HashSet()而不是Set set = new Set()  

Map map = new HashMap()而不是HashMap map = new HashMap()

List list = new ArrayList()而不是ArrayList list = new ArrayList();

1.Set,List,map是接口,不能实例化,只能实例化接口实现类,HashSet,ArrayList,HashMap

2.实现类中的属性和方法set,map,list不能调用,只能调用接口本身属性和方法

3.接口有多个实现类,便于代码的重构,以后只需改实现类,其他可不变

Eg:我是老板A,有两个员工B,C。我现在有一个任务,目的是完成任务,须根据我的想法授权于B或者C,不能让B自己按自己想法完成(B b= new B(),若后面老板想换人(A a= new C()

集合转数组

List list = new ArrayList();

String[] str =  (String[]) list.toArray(new String[list.size()])

数组转集合

String [] str = {"1","1","1","1"};

List list = Arrays.asList(str);

 

框架:

面试必问的东西。一般来说会问你一下你们项目中使用的框架,然后给你一些场景问你用框架怎么做,比如我想要在Spring初始化bean 的时候做一些事情该怎么做、想要在bean销毁的时候做一些事情该怎么做、MyBatis$#的区别等等,这些都比较实际了,平时积累得好、有多学习 框架的使用细节自然都不成问题。

如果上面你的问题答得好,面试官往往会深入地问一些框架的实现原理。问得最多的就是Spring AOP的实现原理,当然这个很简单啦,两句话就搞定的的事儿,即使你不会准备一下就好了。我遇到的最变态的是让我画一下SpringBean工厂实 现的UML

至少,要对用过的框架原理要熟知

Spring IOCAOP原理,如何自己实现IOC,AOP

SpringMVC原理

Springboot原理

Spring cloud原理

Dubbo原理

MyBatis原理

Redis原理

 

数据库

数据库十有八九也都会问到。一些基本的像right joinfull  joinleft join、几种索引及其区别就不谈了,比较重要的就是数据库性能的优化,如果对于数据库的性能优化一窍不通,那么有时间,还是建议你在面试前花一两天专门 把SQL基础和SQL优化的内容准备一下。
不过数据库倒是不用担心,一家公司往往有很多部门,如果你对数据库不熟悉而基本技术又非常好,九成都是会要你的,估计会先把你放到对数据库使用不是要求非常高的部门锻炼一下。

 

Java虚拟机
《深入理解Java虚拟机:JVM高级特性与最佳实践》
Java虚拟机中比较重要的内容:
(1)Java虚拟机的内存布局
(2)GC算法及几种垃圾收集器
(3)类加载机制,也就是双亲委派模型
(4)Java内存模型
(5)happens-before规则
(6)volatile关键字使用规则

 

设计模式
设计模式在工作中还是非常重要、非常有用的,23种设计模式中重点研究常用的十来种就可以了,面试中关于设计模式的问答主要是三个方向:
(1)你的项目中用到了哪些设计模式,如何使用。
(2)知道常用设计模式的优缺点。
(3)能画出常用设计模式的UML图。

 

多线程
因为三年工作经验,所以基本上不会再问你怎么实现多线程了,会问得深入一些比如说ThreadRunnable的区别和联 系、多次start一个线程会怎么样、线程有哪些状态。


假如有Thread1Thread2ThreaD3Thread4四条线程分别统计CDEF四个盘的大小,所有线程都统计完毕交给Thread5线程去做汇总,应当如何实现?
聪明的网友们对这个问题是否有答案呢?不难,java.util.concurrent下就有现成的类可以使用。
另外,线程池也是比较常问的一块,常用的线程池有几种?这几种线程池之间有什么区别和联系?线程池的实现原理是怎么样的?实际一些的,会给你一些具体的场景,让你回答这种场景该使用什么样的线程池比较合适。
最后,虽然这次面试问得不多,但是多线程同步、锁这块也是重点。synchronizedReentrantLock的区别、 synchronized锁普通方法和锁静态方法、死锁的原理及排查方法等等。


JDK源码
要想拿高工资,JDK源码不可不读。上面的内容可能还和具体场景联系起来,JDK源码就是实打实地看你平时是不是爱钻研了。我面试过程中被问了不 少JDK源码的问题,其中最刁钻的一个问了我,StringhashCode()方法是怎么实现的,幸好我平时String源代码看得多,答了个大 概。
JDK源码其实没什么好总结的,纯粹看个人,总结一下比较重要的源码:
(1)ListMapSet实现类的源代码
(2)ReentrantLockAQS的源代码
(3)AtomicInteger的实现原理,主要能说清楚CAS机制并且AtomicInteger是如何利用CAS机制实现的
(4)线程池的实现原理
(5)Object类中的方法以及每个方法的作用
这些其实要求蛮高的,是值得的--不仅仅是为了应付面试。



你可能感兴趣的:(JAVA,生活)