热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java高级工程师进阶学习—Java热修复原理

开篇介绍个人背景:不说太多废话,但起码要让你先对我有一个基本的了解。本人毕业于浙江某二本院校,算是科班出身,毕业后就进了
开篇介绍

个人背景:

不说太多废话,但起码要让你先对我有一个基本的了解。本人毕业于浙江某二本院校,算是科班出身,毕业后就进了一家外包公司做开发,当然不是阿里的外包,具体什么公司就不透露了,在外包一呆就呆了整整2年多,直到现在才从外包离开,如今拿到阿里的offer准备入职了。

阐述原因:

在外包公司的两年里,作为一名菜鸡,确实非常合格,技术没什么长进,眼见也没有提升,没规划没未来,让人实在焦虑,之所以开始改变自己也是家庭发生了变故,才让自己开始思考人生。身边很多人感叹过,能从外包逆袭,算是传奇,所以今天想要分享一下个人的经历,希望能够鼓励到一些与我有相似经历的同行。

注意:这次面试过程比较长,内容繁多,在文章中我基本上简述了,文章里的面试题完整版和我个人的总结方法经验(面试学习和刷题笔记),都整理有PDF完整版,如有需要可以看文末


01 JAVA基础


1.1 java知识点


  • Hashmap 源码级掌握,扩容,红黑树,最小树化容量,hash冲突解决,有些面试官会提出发自灵魂的审问,比如为什么是红黑树,别的树不可以吗;为什么8的时候树化,4不可以吗,等等
  • concureentHashMap,段锁,如何分段,和hashmap在hash上的区别,性能,等等
  • HashTable ,同步锁,这块可能会问你synchronized关键字 1.6之后提升了什么,怎么提升的这些
  • ArrayList 优势,扩容,什么时候用
  • LinkedList 优势,什么时候用,和arraylist的区别 等等
  • 基本类型和包装类型的区别,涉及自动装箱和拆箱,怎么做的,原理
  • String ,StringBuffer,StringBuilder哪个是安全的
  • 字符串编码的区别,被问到过,我觉得比较容易被忽视的一个点
  • 什么是泛型,怎么用泛型
  • static能不能修饰threadLocal,为什么,这道题我当时一听到其实挺懵逼的
  • Comparable和Comparator接口是干什么的,其区别
  • 多态的原理是什么,感觉这个很容易被问到
  • 接口和抽象类,面试官问我是怎么理解的,我说接口对应功能,抽象类对应属性,然后面试官给我说了他的看法,说抽象类更偏向于一种模板~ 然后又交流了一下各自的想法
  • 如何通过反射和设置对象私有字段的值
  • 快速失败(fail-fast)和安全失败(fail-safe)的区别是什么
  • synchronized 的实现原理以及锁优化?
  • volatile 的实现原理?
  • Java 的信号灯?
  • synchronized 在静态方法和普通方法的区别?
  • 怎么实现所有线程在等待某个事件的发生才会去执行?
  • CAS?CAS 有什么缺陷,如何解决?
  • synchronized 和 lock 有什么区别?
  • Hashtable 是怎么加锁的 ?
  • List,Map,Set接口在取元素师,各有什么特点
  • 如何线程安全的实现一个计数器
  • 生产者消费者模式,要求手写过代码,还是要知道的
  • 单例模式,饿汉式,懒汉式,线程安全的做法,两次判断instance是否为空,每次判断的作用是什么。
  • 线程池,这个还是很重要的,在生产中用的挺多,四个线程池类型,其参数,参数的理解很重要,corepoolSize怎么设置,maxpoolsize怎么设置,keep-alive各种的,和美团面试官探讨过阻塞队列在生产中的设置,他说他一般设置为0,防止用户阻塞
  • cyclicbarrier 和countdownlatch的区别,个人理解 赛马和点火箭
  • 线程回调,这块 被问过让我设计一个RPC,怎么实现,其实用到了回调这块的东西
  • sleep 和yeild方法有什么区别
  • volatile关键字,可见性。
  • 乐观锁和悲观锁的使用场景
  • 悲观锁的常见实现方式:lock synchronized retreentlock
  • 乐观锁:CAS MVCC
  • 读写锁的实现方式,16位int的前八位和后八位分别作为读锁和写锁的标志位
  • 死锁的条件,怎么解除死锁,怎么观测死锁。
  • 希望大家能够好好看一下反射的原理,怎么确定类,怎么调方法
  • RPC框架,同步异步,响应时间,这些都被问到过,还让设计过
  • 同步,异步,阻塞,非阻塞 在深信服的面试中遇到过,最好再找一些应用场景加以理解

1.2 JVM


  • 内存模型以及分区,需要详细到每个区放什么。
  • 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。
  • 对象创建方法,对象的内存分配,对象的访问定位。
  • GC 的两种判定方法
  • GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?
  • GC 收集器有哪些?CMS 收集器与 G1 收集器的特点
  • Minor GC 与 Full GC 分别在什么时候发生?
  • JVM 内存分哪几个区,每个区的作用是什么?
  • 如和判断一个对象是否存活?(或者 GC 对象的判定方法)
  • java 中垃圾收集的方法有哪些?
  • 类加载器双亲委派模型机制?
  • java 内存模型,java 类加载过程?
  • 什么是类加载器,类加载器有哪些?
  • 简述 java 内存分配与回收策率以及 Minor GC 和Major GC

02 数据库


2.1 MySQL


  • 事务四大特性(ACID)原子性、一致性、隔离性、持久性?
  • 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?
  • MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?
  • MySQL的MyISAM与InnoDB两种存储引擎在,事务、锁级别,各自的适用场景?
  • 查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序
  • 索引为什么要用B+树,B+树和B-树的区别是什么
  • mysql的默认事务级别,一共有哪些事务级别
  • mysql的一些语句,这些肯定需要掌握的
  • mysql锁,行锁,表锁 ,什么时候发生锁,怎么锁,原理
  • 数据库优化,最左原则啊,水平分表,垂直分表
  • 什么是临时表,临时表什么时候删除?
  • MySQL B+Tree索引和Hash索引的区别?
  • sql查询语句确定创建哪种类型的索引?如何优化查询?
  • 聚集索引和非聚集索引区别?
  • 有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?
  • 非关系型数据库和关系型数据库区别,优势比较?
  • 数据库三范式,根据某个场景设计数据表?
  • 数据库的读写分离、主从复制,主从复制分析的 7 个问题?
  • 使用explain优化sql和索引?
  • MySQL慢查询怎么解决?
  • 什么是 内连接、外连接、交叉连接、笛卡尔积等?
  • mysql都有什么锁,死锁判定原理和具体场景,死锁怎么解决?
  • varchar和char的使用场景?
  • mysql 高并发环境解决方案?
  • 数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)?

03 Spring相关


spring的两大特性- ioc aop,实现原理


  • 如果存在A依赖B,B依赖A,那么是怎么加到IOC中去的
  • beanFactory的理解,怎么加载bean
  • FactoryBean的理解
  • 基于注解的形式,是怎么实现的, 你知道其原理吗,说一下
  • 依赖冲突,有碰到过吗,你是怎么解决的~
  • bean的生命周期
  • spring中的自动装配方式
  • BeanFactory 和 FactoryBean
  • Spring IOC 的理解,其初始化过程?
  • BeanFactory 和 ApplicationContext?
  • Spring Bean 的生命周期,如何被管理的?Spring Bean 的加载过程是怎样的?
  • 如果要你实现Spring AOP,请问怎么实现?
  • 如果要你实现Spring IOC,你会注意哪些问题?
  • Spring 是如何管理事务的,事务管理机制?
  • Spring 的不同事务传播行为有哪些,干什么用的?
  • Spring 中用到了那些设计模式?
  • Spring MVC 的工作原理?
  • Spring 循环注入的原理?
  • Spring 如何保证 Controller 并发的安全?
  • 你一般是怎么对mvc项目进行分层的
  • dispatch-servlet的工作原理
  • 为什么有了springmvc还要在项目中使用spring?
  • springmvc的运行机制,dispatch -》 hanldermapping-—》handler -》handlerAdapter-》执行handler-》modelandview -》 返回mv -》 视图解析器-》返回view -》 渲染响应
  • 怎么防止依赖注入
  • 怎么让mapper 和xml对应
  • 如何自动包装对象
  • 和spring相比,做了什么改变
  • starter你知道哪些
  • 如何部署springmvc项目 以及如何部署springboot项目
  • springboot的插件,你使用过哪些

04 中间件


4.1 redis


  • Redis用过哪些数据数据,以及Redis底层怎么实现
  • Redis缓存穿透,缓存雪崩
  • 如何使用Redis来实现分布式锁
  • Redis的并发竞争问题如何解决
  • Redis持久化的几种方式,优缺点是什么,怎么实现的
  • Redis的缓存失效策略
  • Redis集群,高可用,原理
  • Redis缓存分片,Redis的数据淘汰策略
  • 为什么选择redis,有什么好处,基于内存,抗压
  • redis集群怎么进行数据分配,hash槽
  • redis的主从复制是怎么实现的
  • redis的数据结构 最常问 hash是什么, sorted set怎么实现的
  • 因为项目的原因,问我redis是怎么保证高可用的,主从和集群怎么加在一起
  • redis 和memcache的区别
  • redis 分布式锁的实现原理 setNX 啥的
  • redis模拟session,除了redis你还考虑过别的吗
  • redis的缓存击穿,怎么处理这个问题
  • redis是基于内存的,那么它有持久化吗,aof rdb
  • aof和rdb的优缺点,你在项目中使用的哪一个

4.2 MQ


  • 为什么选择rabbitMQ, 社区活跃,高并发
  • 别的MQ也要了解,比如RocketMQ(阿里的,java开发,再次开发,并发高,分布式,出错少)
  • ActiveMQ, kafka
  • topic 和 block
  • MQ的作用,同步转异步,消除峰值
  • 如何保证数据一致性,即原子性,ack
  • 消息队列在项目中的应用

4.3 nginx


  • 怎么配置负载均衡
  • 怎么限流
  • 怎么使用nginx缓存
  • 为什么使用nginx,有别的替代品吗
  • 请解释 x Nginx 如何处理 P HTTP 请求
  • 在 x Nginx 中,如何使用未定义的服务器名称来阻止处理请求? ?
  • 使用“ 反向代理服务器 ” 的优点是什么?
  • x Nginx 服务器上的 r Master 和 和 r Worker 进程分别是什么?
  • nginx的压力测试,你测试过吗,能抗住多少压力
  • 你如何通过不同于 0 80 的端口开启 Nginx?
  • 是否有可能将 x Nginx 的错误替换为 2 502 错误、 503
  • s stub_status 和 和 r sub_filter 指令的作用是什么? ?

4.5 dubbo


  • 原理,怎么用
  • 和erueka有什么区别
  • 为什么要用dubbo,不用行不行?
  • 跨域请求的一些知识点
  • Dubbo 支持哪些协议,每种协议的应用场景,优缺点?
  • Dubbo 超时时间怎样设置?
  • Dubbo 集群的负载均衡有哪些策略
  • Dubbo 的主要应用场景?
  • Dubbo 服务注册与发现的流程?
  • Dubbo 中 中 zookeeper 做注册中心,如果注册中心集群都挂掉,发布者和订阅者之间还能通信么?
  • dubbo 服务负载均衡策略?

05 其他插件


5.1 shiro


  • 怎么做权限控制
  • 为什么使用shiro,你直接使用aop不也是一样的吗,shiro还有标签~各种扯
  • shiro的两个最重要的函数
  • 认证和授权是怎么做的

5.2 docker


  • 和vmware的区别
  • 你一般是怎么部署的 IDEA,直接把项目部署到docker并打包到云服务器
  • docker的好处,小,快

06 Linux


  • 常见的命令
  • sed 和 awk 感觉linux必考。。
  • linux的使用场景,你什么时候会用linux – 》 布置服务器
  • 怎么查看进程和杀死进程
  • 打印一个文件夹中的所有文件
  • float在计算机中是怎么存储的,当时被问到的时候,我也在问自己,怎么存的~~~ 佛了
  • 线程和进程的区别
  • 线程的通信方式,进程的通信方式
  • 系统线程的数量上限是多少
  • 页式存储的概念
  • 内存碎片,你有了解过吗,有想过解决方案吗~

07 算法


7.1 排序算法


  • 八大排序算法真的是面试宠儿
  • 最常考 快速排序 和归并排序
  • 哪些排序算法是稳定的 哪些是不稳定的
  • 堆排 也应该掌握

7.2 树


  • 根据遍历结果恢复树,递归
  • 二叉搜索树第k大
  • 树的和为k的路径
  • 层次遍历
  • 根据层次遍历和后序遍历恢复树
  • 镜像树
  • 树的深度
  • 是不是平衡二叉树

7.3 链表


  • 反转链表
  • 链表环的入口
  • 交叉链表的交点
  • 复杂链表的复制
  • 二叉搜索树变成双向链表

7.4 回溯算法


  • 走迷宫
  • 游戏通关

7.5 递推算法


  • 走台阶
  • 断钢筋

7.6 背包问题


  • 装最多的东西

7.7 贪心算法


  • 覆盖问题
  • 时间问题

08 设计模式


  • 面试中设计模式其实也是挺重要的
  • Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
  • 在 Java 中,什么叫观察者设计模式(observer design pattern)
  • 使用工厂模式最主要的好处是什么?在哪里使用
  • 举一个用 Java 实现的装饰模式(decorator design pattern) ?它是作用于对象层次还是类层次?
  • 在 Java 中,什么时候用重载,什么时候用重写?
  • 举例说明什么情况下会更倾向于使用抽象类而不是接口
  • 观察者模式
  • 适配模式
  • 工厂模式

最后

给大家送一个小福利

资料都是免费分享的,附送高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。点我免费领取!!!

?

  • 举例说明什么情况下会更倾向于使用抽象类而不是接口
  • 观察者模式
  • 适配模式
  • 工厂模式

最后

给大家送一个小福利

[外链图片转存中…(img-MkeqzbmK-1624683903262)]

资料都是免费分享的,附送高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。点我免费领取!!!

[外链图片转存中…(img-rm7bAKPj-1624683903264)]


推荐阅读
  • 本文深入解析了JDK 8中HashMap的源代码,重点探讨了put方法的工作机制及其内部参数的设定原理。HashMap允许键和值为null,但键为null的情况只能出现一次,因为null键在内部通过索引0进行存储。文章详细分析了capacity(容量)、size(大小)、loadFactor(加载因子)以及红黑树转换阈值的设定原则,帮助读者更好地理解HashMap的高效实现和性能优化策略。 ... [详细]
  • Java并发机制详解及其在数据安全性保障中的应用方案 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • Spring – Bean Life Cycle
    Spring – Bean Life Cycle ... [详细]
  • 使用Java 1.8 编译兼容1.6 JVM 的Class文件
    本文探讨了如何使用Java 1.8 编译器生成能够在1.6 JVM 上运行的Class文件,并介绍了Spring框架中的相关配置。 ... [详细]
  • 阿里巴巴终面技术挑战:如何利用 UDP 实现 TCP 功能?
    在阿里巴巴的技术面试中,技术总监曾提出一道关于如何利用 UDP 实现 TCP 功能的问题。当时回答得不够理想,因此事后进行了详细总结。通过与总监的进一步交流,了解到这是一道常见的阿里面试题。面试官的主要目的是考察应聘者对 UDP 和 TCP 在原理上的差异的理解,以及如何通过 UDP 实现类似 TCP 的可靠传输机制。 ... [详细]
  • 深入解析CAS机制:全面替代传统锁的底层原理与应用
    本文深入探讨了CAS(Compare-and-Swap)机制,分析了其作为传统锁的替代方案在并发控制中的优势与原理。CAS通过原子操作确保数据的一致性,避免了传统锁带来的性能瓶颈和死锁问题。文章详细解析了CAS的工作机制,并结合实际应用场景,展示了其在高并发环境下的高效性和可靠性。 ... [详细]
  • 本文探讨了如何利用Java代码获取当前本地操作系统中正在运行的进程列表及其详细信息。通过引入必要的包和类,开发者可以轻松地实现这一功能,为系统监控和管理提供有力支持。示例代码展示了具体实现方法,适用于需要了解系统进程状态的开发人员。 ... [详细]
  • 本文介绍了如何利用ObjectMapper实现JSON与JavaBean之间的高效转换。ObjectMapper是Jackson库的核心组件,能够便捷地将Java对象序列化为JSON格式,并支持从JSON、XML以及文件等多种数据源反序列化为Java对象。此外,还探讨了在实际应用中如何优化转换性能,以提升系统整体效率。 ... [详细]
  • 在Ubuntu上安装MySQL时解决缺少libaio.so.1错误及libaio在MySQL中的重要性分析
    在Ubuntu系统上安装MySQL时,遇到了缺少libaio.so.1的错误。本文详细介绍了如何解决这一问题,并深入探讨了libaio库在MySQL性能优化中的重要作用。对于初学者而言,理解这些依赖关系和配置步骤是成功安装和运行MySQL的关键。通过本文的指导,读者可以顺利解决相关问题,并更好地掌握MySQL在Linux环境下的部署与管理。 ... [详细]
  • 在Android应用开发中,实现与MySQL数据库的连接是一项重要的技术任务。本文详细介绍了Android连接MySQL数据库的操作流程和技术要点。首先,Android平台提供了SQLiteOpenHelper类作为数据库辅助工具,用于创建或打开数据库。开发者可以通过继承并扩展该类,实现对数据库的初始化和版本管理。此外,文章还探讨了使用第三方库如Retrofit或Volley进行网络请求,以及如何通过JSON格式交换数据,确保与MySQL服务器的高效通信。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • 提升Android开发效率:Clean Code的最佳实践与应用
    在Android开发中,提高代码质量和开发效率是至关重要的。本文介绍了如何通过Clean Code的最佳实践来优化Android应用的开发流程。以SQLite数据库操作为例,详细探讨了如何编写高效、可维护的SQL查询语句,并将其结果封装为Java对象。通过遵循这些最佳实践,开发者可以显著提升代码的可读性和可维护性,从而加快开发速度并减少错误。 ... [详细]
  • Android中将独立SO库封装进JAR包并实现SO库的加载与调用
    在Android开发中,将独立的SO库封装进JAR包并实现其加载与调用是一个常见的需求。本文详细介绍了如何将SO库嵌入到JAR包中,并确保在外部应用调用该JAR包时能够正确加载和使用这些SO库。通过这种方式,开发者可以更方便地管理和分发包含原生代码的库文件,提高开发效率和代码复用性。文章还探讨了常见的问题及其解决方案,帮助开发者避免在实际应用中遇到的坑。 ... [详细]
  • 初探性能优化:入门指南与实践技巧
    在编程领域,常有“尚未精通编码便急于优化”的声音。为了从性能优化的角度提升代码质量,本文将带领读者初步探索性能优化的基本概念与实践技巧。即使程序看似运行良好,数据处理效率仍有待提高,通过系统学习性能优化,能够帮助开发者编写更加高效、稳定的代码。文章不仅介绍了性能优化的基础知识,还提供了实用的调优方法和工具,帮助读者在实际项目中应用这些技术。 ... [详细]
author-avatar
韵公举_R
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有