眼看疫情已经好转,也不能继续待在家,很多公司也辞退了好多人,甚至有人找到工作还没有去工作就收到不用来公司的通知。这也说明了拥有强硬的技术才是硬道理,这篇文章是我花费一个半小时整理的,是目前可以找到最全的问题以及技术了,总共有八百多道。所以你们如果能全部掌握,基本就能收割 offer 了。时间有限的话,针对自己的情况优先选最有可能被问到的问题来准备。
文中的题大部分都包含了答案,希望对要参加面试的读者有一定的帮助,这是小编为了准备面试各个大厂所准备的面试题,除了收集的283页的高级Java面试题之外,还整理很多当下热门的技术:MySQL、Redis、Dubbo、Spring、数据库、负载均衡、设计模式、数据库等面试专题的整合(pdf文档)。
多线程与高并发:
- 数据结构
- 算法题
- Java基础
- Java高级
- 三大框架
- 数据库
- 操作系统
- 计算机网络
- 分布式,集群等高级主题
- 技术开放题
- 题目参考
- 解答参考
文章是关于面试的知识技术点,宅在家两周整理出来的,有需要的小伙伴可以继续看下去。文末有完整的领取方式~
数据结构
- 讲一下 HashMap 中 put 方法过程?
- HashMap 中 hash 函数怎么是是实现的? 还有哪些 hash 的实现方式?
- HashMap 怎样解决冲突,讲一下扩容过程,假如一个值在原数组中,现在移动了新数组,位置肯定改变了,那是什么定位到在这个值新数组中的位置,
- 默认容量: 16(2^n 为宜,若定义的初始容量不是 2^n,容量会定义为大于该初始容量的最小 2^n)
- 当总元素个数超过容量*加载因子时,扩容为原来 2 倍并重新散列
- HashTable
- HashMap ,HashTable 区别
- HashMap、ConcurrentHashMap 区别。
- 默认容量: 16(若定义了初始容量(c),容量会定义为大于(c + (c >>> 1) +1) 的最小 2^n)
- 线程安全,并发性能较好
- ConcurrentHashMap 原理
- 最大特点是引入了 CAS(借助 Unsafe 来实现【native code】)
- 使用实例:
- sizeCtl :默认为0,用来控制 table 的初始化和扩容操作。
- CAS 会出现的问题:ABA
- 如果想实现一个线程安全的队列,可以怎么实现?
- 知道 LRU 吗,20分钟基于 HashMap 实现一个 LRU 算法,面试官给个地址,进去写代码,面试官远程看
- 二叉树的遍历方式,前序、中序、后序和层序
- 常见的排序算法时间复杂度(排序算法实现也要重点掌握)
算法题
- 怎么查询一个单向链表的倒数第五个节点
- 判断链表是否成环
- 两条相交的单向链表,如何求他们的第一个公共节点
- 在无序数组中找最大的K个数?
- 给定n个数,寻找第k小的数,同时给出时间复杂度
- 找一个数组中的第三大数
- 找出数组中第一个出现2次的数,
- 求 1-N 中数字 1 的个数。
- 判断一个数是不是丑数;
- 求第 K 个丑数;
- 10w行数据,每行一个单词,统计出现次数出现最多的前100个。
- 一个文本文件,给你一个单词,判断单词是否出现。
- 一进去要求敲代码二叉排序树的插入、删除及查找
- 某海量用户网站,用户拥有积分,积分可能会在使用过程中随时更新。现在要为该网站设计一种算法,在每次用户登录时显示其当前积分排名。用户最大规模为2 亿;积分为非负整数,且小于 100 万;
Java 基础
- Java 的优势
- boolean 占几个字节
- Java 访问修饰符权限的区别;
- String 是否可以继承, “+” 怎样实现?
- String,StringBuffer,StringBuilder,区别,项目中那里用到了 StringBuffer 或者 StringBuilder
- String为啥不可变,在内存中的具体形态?
- Comparable 接口和 Comparator 接口实现比较
- Arrays 静态类如何实现排序的?
- Java 中异常怎么处理,什么时候抛出,什么时候捕获;
- Java 锁机制
- 重入锁、对象锁、类锁的关系
- 哪些方法实现线程安全?
- Java 中的同步机制,synchronized 关键字,锁(重入锁)机制,其他解决同步的方 volatile 关键字 ThreadLocal 类的实现原理要懂。
- Synchronized 和 lock 区别
- 锁的优化策略
- Java线程阻塞调用 wait 函数和 sleep 区别和联系,还有函数 yield,notify 等的作用。
三大框架
- Spring 主要思想是什么,回答 IOC 和AOP,怎么自己实现 AOP ?
- SpringAOP 用的哪一种代理
- spring bean 初始化过程
- spring bean 对象的生命周期
- 讲讲 Spring 中 ApplicationContext 初始化过程。
- SpringMVC 处理请求的流程
- SpringMVC 的设计模式
- Spring 的 annotation 如何实现
- Spring拦截器怎么使用,Controller是单例吗
数据库
- SQL 优化方案
- 根据我目前的知识水平,大概分为两类:
- 判断当前的 SQL 是否合理的使用了索引。如果设置的索引没有使用的话,会导致全表扫描。效率上会差很多。没有利用索引的情况一般有以下几种:
- 索引有哪些?分别有什么特点?
- 索引为什么用 B 树不用二叉树,有什么好处?
- 基于 B 树的索引实现,降低了树的高度,减少了磁盘 IO 的次数。
- 数据库索引优点和缺点
- 优点:有效加速查询;
- 缺点:操作数据时需要对索引进行更新,效率上稍微差一点;索引需要占用一定的空间。
- 数据库事务的四个隔离级别,MySql 在哪一个级别
MySQL 默认隔离级别为 Repeatable read
操作系统
- 进程和线程的区别
- 进程是拥有资源的基本单位,线程是 CPU 调度的基本单位
- 一个进程必须至少拥有一个线程
- 一个线程死掉就等于整个进程死掉,所以多进程的程序相对于多线程的程序来说会更健壮
- 通信方式不同,线程通过进程内的资源进行通信,进程的通信有多种方式,包括管道、共享内存、消息等等。
- 进程间通信
- 信号(Signal):信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身;报文(Message)队列(消息队列):消息队列是消息的链接表。有足够权限的进程可以向队列中添加消息,被赋予读权限的进程则可以读走队列中的消息。消息队列克服了信号承载信息量少,管道只能承载无格式字节流以及缓冲区大小受限等缺点。
计算机网络
- HTTP 状态码有哪些,一一解释含义
- 1xx 消息
- 2xx 成功
- 3xx 重定向
- 4xx: 客户端错误
- 400 Bad Request 服务器未能理解请求。
- 404 Not Found 服务器无法找到被请求的页面。
- 5xx: 服务器错误
- 500 Internal Server Error 请求未完成。服务器遇到不可预知的情况。
- HTTP 请求头有哪些,介绍平时见过的,怎么利用这些信息来进行前后端调试
- Host, 请求的域名
- User-Agent,用户的浏览器版本信息
- Accept,相应的内容类型
- Accept-Language, 接受的语言
- TCP 和 UDP 的区别
分布式/集群等高级主题
- 负载均衡算法
- 随机:负载均衡方法随机的把负载分配到各个可用的服务器上。
- 轮询:按顺序将新的连接请求分配给下一个服务器
- 加权轮询:每台服务器接受到的连接数按权重分配,一般是用在应用服务器的处理能力大小不同的情况下。
- 最少连接:把新连接分配给当前连接最少的服务器
- BLABAL...
- 分布式数据库
- 分布式数据库提供了原来集中式数据库不具备的高可用性和拓展能力
读者福利、完整面试题【含答案】
Java核心笔记,Java架构面试专题整合800道(pdf文档)总共283页,Si xin即可。
转载:https://blog.csdn.net/Ppikaqiu/article/details/106244377
查看评论