JAVA程序员备战跳槽季,准备面试必备的技术大纲,请查收
跳槽时时刻刻都在发生,但是我建议大家跳槽之前,先想清楚为什么要跳槽。切不可跟风,看到同事一个个都走了,自己也盲目的开始面试起来(期间也没有准备充分),到底是因为技术原因(影响自己的发展,偏移自己规划的轨迹),还是钱给少了,不受重视。
那怎样才能通过BAT面试官的考核?怎样成为一名Offer收割机?
之前动态有说过:Offer=硬实力软实力好的心态,三者缺一不可。
硬实力
这里说的硬实力,也就是技术上的真实积累。
怎么来体现你的技术实力?我总的分为:技术深度和技术广度这两方面。技术广度通俗的讲,就是你熟悉该技术点的使用以及基本原理。一般面试官在面试首轮会问很多技术点,来考核你是否能正确使用。
准备不充分的面试,完全是浪费时间,更是对自己的不负责(如果title很高,当我没说)。
今天给大家分享下在跳槽时需要准备的Java面试大纲,其中大部分都是面试过程中的面试题,可以对照这查漏补缺,当然了,这里所列的肯定不可能覆盖全部方式。
项目介绍
大部分情况,这是一场面试的开门题,面试官问这个问题,主要是考察你的概述能力和全局视野。有的人经常抱怨自己每天在堆业务,但没有成长。事实上,很多情况下确实在堆业务,但并不是没有成长的。并非做中间件或者技术架构才是成长,例如我们的需求分析能力,沟通协作能力,产品思维能力,抽象建模能力等都是一个非常重要的硬实力。
Java基础
List 和 Set 的区别
HashSet 是如何保证不重复的
HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?HashMap 的扩容过程
HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?
final finally finalize
强引用 、软引用、 弱引用、虚引用
Java反射
Java 并发
synchronized 的实现原理以及锁优化?
volatile 的实现原理?
Java 的信号灯?
synchronized 在静态方法和普通方法的区别?
怎么实现所有线程在等待某个事件的发生才会去执行?
CAS?CAS 有什么缺陷,如何解决?
synchronized 和 lock 有什么区别?
Hashtable 是怎么加锁的 ?
HashMap 的并发问题?
ConcurrenHashMap 介绍?1.8 中为什么要用红黑树?
AQS
如何检测死锁?怎么预防死锁?
Java 内存模型?
如何保证多线程下 i++ 结果正确?
线程池的种类,区别和使用场景?
分析线程池的实现原理和线程的调度过程?
线程池如何调优,最大数目如何确认?
ThreadLocal原理,用的时候需要注意什么?
Spring
BeanFactory 和 FactoryBean?
Spring IOC 的理解,其初始化过程?
BeanFactory 和 ApplicationContext?
Spring Bean 的生命周期,如何被管理的?
Spring Bean 的加载过程是怎样的?
如果要你实现Spring AOP,请问怎么实现?
如果要你实现Spring IOC,你会注意哪些问题?
Spring 是如何管理事务的,事务管理机制?
Spring 的不同事务传播行为有哪些,干什么用的?
Spring 中用到了那些设计模式?
Netty
BIO、NIO和AIO
Netty 的各大组件
Netty的线程模型
TCP 粘包/拆包的原因及解决方法
了解哪几种序列化协议?包括使用场景和如何去选择
Netty的零拷贝实现
Netty的高性能表现在哪些方面
分布式相关
Dubbo的底层实现原理和机制
描述一个服务从发布到被消费的详细过程
分布式系统怎么做服务治理
接口的幂等性的概念
消息中间件如何解决消息丢失问题
Dubbo的服务请求失败怎么处理
重连机制会不会造成错误
对分布式事务的理解
如何实现负载均衡,有哪些算法可以实现?
Zookeeper的用途,选举的原理是什么?
数据的垂直拆分水平拆分。
zookeeper原理和适用场景
zookeeper watch机制
redis/zk节点宕机如何处理
分布式集群下如何做到唯一序列号
如何做一个分布式锁
缓存
Redis用过哪些数据数据,以及Redis底层怎么实现
Redis缓存穿透,缓存雪崩
如何使用Redis来实现分布式锁
Redis的并发竞争问题如何解决
Redis持久化的几种方式,优缺点是什么,怎么实现的
Redis的缓存失效策略
Redis集群,高可用,原理
Redis缓存分片
Redis的数据淘汰策略
JVM
详细jvm内存模型
讲讲什么情况下回出现内存溢出,内存泄漏?
说说Java线程栈
JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
JVM 出现 fullGC 很频繁,怎么去线上排查问题?
类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式?
类的实例化顺序
JVM垃圾回收机制,何时触发MinorGC等操作
JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
各种回收器,各自优缺点,重点CMS、G1
各种回收算法
OOM错误,stackoverflow错误,permgen space错误
软实力
软实力在面试过程中也尤为重要(有时候真的要更重要),主要是指和面试官的沟通,对一个问题的阐述方式和表达方式,逻辑思维能力等。
面试过程全程微笑,项目描述需要严谨的表述,个人的优缺点基本要做到随口而出..等这些其实就是软实力的体现。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
如何编写高质量的 JS 函数(2) -- 命名/注释/鲁棒篇
本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/sd2oX0Z_cMY8_GvFg8pO4Q 作者:杨昆 上篇 《如何编写高质量的 JS 函数(1) -- 敲山震虎篇 》介绍了函数的执行机制,此篇将会从函数的命名、注释和鲁棒性方面,阐述如何编写高质量的 JS 函数。 (一)函数命名 一、目前前端的函数命名存在什么问题 从上图可以知道,命名和缓存是计算机科学中的两大难题。 本文要说的函数命名,虽然涉及到的范围较窄,但思想都一样,完全可以借鉴到其他的形式中。 之前阅读过代码大全中变量的相关章节,也针对性的了解过一些源码,根据我的经验总结,目前函数命名除了业界标准的问题外,还存在一些细节的问题,比如: 中英语言的差异性 不懂得从多维度去提升命名的准确性(如何从多维度去提升命名的准确性) 不会使用辅助工具(如何使用辅助工具) 下面进行简明扼要的分析。 二、汉语和英语的差异性 1、为什么不能用汉语方式命名呢? 汉语拼音存在多义性;汉字翻译的辅助工具还不够普及,因此不能用汉语方式命名。 2、用英语时遇到的困难 最大的难点在于语法的正确使用场景...
- 下一篇
SpringBoot2 整合 FastDFS 中间件,实现文件分布式管理
本文源码:GitHub·点这里 || GitEE·点这里 一、FastDFS简介 1、FastDFS作用 FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件上传、文件下载等,解决了大容量存储和负载均衡的问题。 安装连接: 安装流程详解 2、核心角色 FastDFS是由跟踪服务器(trackerserver)、存储服务器(storageserver)和客户端(client)三个部分组成。 1)跟踪服务器 FastDFS的协调者,负责管理所有的storage server和group,每个storage在启动后会连接Tracker,告知自己所属的group等信息,并保持周期性的心跳,tracker根据storage的心跳信息,建立group到[storage server list]的映射表。 2)存储服务器 以组(group)为单位,一个group内包含多台storage机器,数据互为备份,存储空间以group内容量最小的storage为准,所以建议group内的多个storage尽量配置相同,以免造成存储空间的浪费。 3)客户端 业务请...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS8编译安装MySQL8.0.19
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS关闭SELinux安全模块
- 设置Eclipse缩进为4个空格,增强代码规范
- SpringBoot2整合Redis,开启缓存,提高访问速度