Java程序员的基本技能
基本语法
这包括static、final、transient等关键字的作用,foreach循环的原理等等。今天面试我问你static关键字有哪些作用,如果你答出static修饰变量、修饰方法我会认为你合格,答出静态块,我会认为你不错,答出静态内部类我会认为你很好,答出静态导包我会对你很满意,因为能看出你非常热衷研究技术。
集合
非常重要,也是必问的内容。基本上就是List、Map、Set,问的是各种实现类的底层实现原理,实现类的优缺点。
集合要掌握的是ArrayList、LinkedList、Hashtable、HashMap、ConcurrentHashMap、HashSet的实现原理,能流利作答,当然能掌握CopyOnWrite容器和Queue是再好不过的了。另外多说一句,ConcurrentHashMap的问题在面试中问得特别多,大概是因为这个类可以衍生出非常多的问题,关于ConcurrentHashMap,我给网友朋友们提供三点回答或者是研究方向:
§ ConcurrentHashMap的锁分段技术
§ ConcurrentHashMap的读是否要加锁,为什么
§ ConcurrentHashMap的迭代器是强一致性的迭代器还是弱一致性的迭代器
设计模式
当然咱们不能这么功利,为了面试而学习,设计模式在工作中还是非常重要、非常有用的,23种设计模式中重点研究常用的十来种就可以了,面试中关于设计模式的问答主要是三个方向:
§ 你的项目中用到了哪些设计模式,如何使用
§ 知道常用设计模式的优缺点
§ 能画出常用设计模式的UML图
多线程
这也是必问的一块了。因为三年工作经验,所以基本上不会再问你怎么实现多线程了,会问得深入一些比如说Thread和Runnable的区别和联系、多次start一个线程会怎么样、线程有哪些状态。当然这只是最基本的,出乎意料地,几次面试几乎都被同时问到了一个问题,问法不尽相同,总结起来是这么一个意思:
假如有Thread1、Thread2、ThreaD3、Thread4四条线程分别统计C、D、E、F四个盘的大小,所有线程都统计完毕交给Thread5线程去做汇总,应当如何实现?
JDK源码
要想拿高工资,JDK源码不可不读。上面的内容可能还和具体场景联系起来,JDK源码就是实打实地看你平时是不是爱钻研了。面试过程中被问了不少JDK源码的问题,其中最刁钻的一个问了String的hashCode()方法是怎么实现的,幸好平时String源代码看得多,答了个大概。JDK源码其实没什么好总结的,纯粹看个人,总结一下比较重要的源码:
§ List、Map、Set实现类的源代码
§ ReentrantLock、AQS的源代码
§ AtomicInteger的实现原理,主要能说清楚CAS机制并且AtomicInteger是如何利用CAS机制实现的
§ 线程池的实现原理
§ Object类中的方法以及每个方法的作用
框架
老生常谈,面试必问的东西。一般来说会问你一下你们项目中使用的框架,然后给你一些场景问你用框架怎么做,比如我想要在Spring初始化bean的时候做一些事情该怎么做、想要在bean销毁的时候做一些事情该怎么做、MyBatis中$和#的区别等等,这些都比较实际了,平时积累得好、有多学习框架的使用细节自然都不成问题。
数据库
数据库十有八九也都会问到。一些基本的像union和union all的区别、left join、几种索引及其区别就不谈了,比较重要的就是数据库性能的优化,如果对于数据库的性能优化一窍不通,那么有时间,还是建议你在面试前花一两天专门把SQL基础和SQL优化的内容准备一下。
不过数据库倒是不用担心,一家公司往往有很多部门,如果你对数据库不熟悉而基本技术又非常好,九成都是会要你的,估计会先把你放到对数据库使用不是要求非常高的部门锻炼一下。
数据结构和算法分析
数据结构和算法分析,对于一名程序员来说,会比不会好而且在工作中绝对能派上用场。数组、链表是基础,栈和队列深入一些但也不难,树挺重要的,比较重要的树AVL树、红黑树,可以不了解它们的具体实现,但是要知道什么是二叉查找树、什么是平衡树,AVL树和红黑树的区别。记得某次面试,某个面试官和我聊到了数据库的索引,他问我:
你知道索引使用的是哪种数据结构实现吗?
Java虚拟机
谈谈Java虚拟机中比较重要的内容:
§ Java虚拟机的内存布局
§ GC算法及几种垃圾收集器
§ 类加载机制,也就是双亲委派模型
§ Java内存模型
§ happens-before规则
§ volatile关键字使用规则
这还只是Java程序员的最基本要求,你不可能在基础的程序员上面干一辈子所以我们只会慢慢的往上走
以下是我收藏的系统学习的图谱:
图谱以及整理的架构师精讲资料,资料获取方式点此链接:https://shimo.im/docs/r8GKP6yWcPhhVWxy
一:分布式架构
高并发,高可用,海量数据,没有分布式的架构知识肯定是玩不转的所以分布式的知识需要掌握:
分布式架构思维
大型互联网架构演进过程
架构师应具备的分布式知识
主流分布式架构设计详解
架构开发基础
多线程开发
高性能NIO框架
架构核心服务层技术
服务的前世今生
深入理解通讯协议
基于分布式RPC解决方案
Dubbo全解析
架构关键基础设施
分布式环境指挥官Zookeeper
分布式消息通讯异步与MQ
分布式缓存
数据存储SQL&NoSQL
高冰分流技术Nginx
分布式架构实战
分布式解决方案
Session跨域共享实战
分布式事务解决方案实战
分布式锁解决方案实战
分布式单点登录实战SSO
分布式调度任务系统
分布式配置中心
二:微服务架构
微服务架构是架构升级的必由之路,Java技术体系,和微服务相关的技术有哪些呢?
SpringBoot
与微服务的区别与联系
快速构建SpringBoot工程
SpringBoot核心组件剖析
快速集成MyBatis实战
快速集成Dubbo及案例实战
快速集成Redis及案例实战
构建Swagger插件实现API
管理及接口测试体系
Spring Cloud
Zuul路由网关详解源码探析
Ribbon客户端负载均衡原理
Feign声明式服务调用方式
Hustnx服务熔断及服务降级
Eureka注册中心构件
Config配置服务中心
Svn、git快速集成
Sleuth调用链路跟踪
BUS消息总线技术
Docker虚拟化技术
介绍、安装与使用
Compose部署脚本
Service服务编排
Redis分布式集群部署
Docker file构建
通过maven插件打包镜像
部署及运行应用程序
Kubernetes编配
构建Mysql集群实战
高可用SpringCloud微服务与docker集成实现动态扩容实战
Dubbo应用及源码解读
Dubbo简介及初入门
Dubbo管理中心及监控系统安装部署
领域驱动之如何正确划分Dubbo分布式服务
通讯协议TCP、UDP、HTTP分析
Dubbo负载均衡机制探析
如何完成Dubbo服务只订阅及只注册模式
架构师必备技术之如何设计Dubbo服务接口
Dubbo设计原理及源码分析
Dubbo容器机制及高扩展性分析
Dubbo服务于Docker虚拟化技术集成实战
三:团队协作开发
工欲善其事必先利其器,不管是小白,还是资深开发,玩Java技术体系,选择好的工具,提升开发效率和团队协作效率,是必不可少的:
Maven,项目管理
Maven重要指令
私服-nexus
Mavenue流行插件实战
手写自己的插件
架构师如何理解scope、Lifecyle、Phase、Goal
Jenkins
Jenkins服务器部署
Jenkins 持续集成
Sonar,代码质量管理
静态代码查询,代码更健壮
代码走查
Git,版本管理
Git基本工作原理
Git常用操作及问题处理
四:性能优化
任何脱离细节的ppt架构师都是耍流氓,向上能运筹帷幄,向下能解决一线性能问题,Java技术体系,需要了解:
性能指标体系
性能基准
什么是性能优化
衡量标准
JVM调优
Jvm虚拟机内存剖析
垃圾收集器
实战调优案例与解决方法
Jvm运行时区
Java程序性能优化
优雅的创建对象
注意对象的通用方法
类的设计陷阱
泛型需要注意的问题
Java方法的那些坑
程序设计的通用规则
Tomcat
线程模型分析
生产环境配置及调优
运行机制及框架
MYSQL
探析BTree机制
执行计划深入分析
Mysql索引优化详解
慢查询分析与SQL优化
图谱以及整理的架构师精讲资料,资料获取方式点此链接:https://shimo.im/docs/r8GKP6yWcPhhVWxy