作为一个初中级程序员,你到底掌握了什么技能?

  • Post author:
  • Post category:其他

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

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

基本语法:

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

Exception和Error区别

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

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

java.util.Date和java.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());

集合
这里写图片描述

这里写图片描述

集合的结构

其中ArrayList和HashMap用到特别多,也是被问到特别多的地方

ArrayList原理

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

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

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

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

特点:

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

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

add函数:

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

过程:

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

set和get函数:

Array的put和get函数就比较简单了,先做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原理:

ArrayList和L‌‌inkedList的大致区别:

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

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

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

HashMap和HashTable和ConcurrentHashMap区别

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

HashMap的键值可以为null,HashTable不能不null,ConcurrentHashMap不能为空

HashMap是HashTable的轻量级实现

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的实现原理,当然这个很简单啦,两句话就搞定的的事儿,即使你不会准备一下就好了。我遇到的最变态的是让我画一下Spring的Bean工厂实 现的UML图

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

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

SpringMVC原理

Springboot原理

Spring cloud原理

Dubbo原理

MyBatis原理

Redis原理

数据库

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

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

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

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

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

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


版权声明:本文为weixin_42833888原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。