Java后端开发 校招实习面试准备

本文详细梳理了Java后端开发的面试知识点,包括JavaSE的面向对象特性、JVM内存区域及GC算法、多线程/锁/并发的原理及应用、数据库的索引和事务处理、操作系统基础、计算机网络、框架如Spring的运作流程,以及设计模式的实战。同时,涵盖了数据结构与算法、场景题和面试技巧,是Java校招实习面试的必备指南。
摘要由CSDN通过智能技术生成


复习博客

一、JavaSE

面向对象的设计思想
Java三大特性
HashMap、ConcurrentHashMap,是否可以存储null值
怎么把hashmap中的数据和最小堆做映射,根据什么建堆
HashMap和TreeMap结构?HashMap为什么要述化?线程安全吗?怎么使之安全?
一个HashMap跟面试官扯了半个小时
hashset是怎么实现的? hashmap是怎么实现hashset的?
HashMap和ConcurrentHashMap哪个效率更高?为什么?
HashMap初始容量多少?(16)为啥要设计初始为16?如果传入容量10会怎么样?(还是会构建16容量的);
Java怎么与数据库交互
JDK8的新特性有哪些
JDK8的stream的操作
Java集合
Arraylist和linkedlist区别
CopyOnWriteArrayList的相关特性?
ArrayList遍历的时候能删除元素吗? 删除的时候会报什么异常?
list,set集合在iterator输出的时候能删去值吗?
重载、重写区别
Object、泛型、通配符区别
队列、栈
StringBuilder StringBuffer区别,Java8的StringBuffer是不是也用了Synchronized
String为什么设计成final不可变? 是怎么实现不可变的?
HashSet原理
sleep,wait区别
TreeMap与HashMap区别?怎么实现的?
优先队列构建过程
java异常?有哪些常见的RuntimeException和非RuntimeException?
异常都有几大类?运行时的空指针会抛异常吗?IO Exception异常发生需要自己去捕获?编译期间需要捕获,运行时不需要捕获,异常捕获处理
int型的变量,如何将它转成String?区别?Integer.toString(xx) ;(new Integer(xx)).toString() ; String.valueOf(xx),第一个是静态方法,第二个要实例化对象
hash冲突怎么解决
类修饰词default和protected关系
抽象类和接口有什么不同
可以不通过构造函数创建对象吗? object.clone() 反序列化
重写equals方法,为什么一定要重写hashcode方法?
equals 和 hashcode 为什么要一起重写?如果不重写hashcode会出现什么问题?
SimpleDateFormat是线程安全的吗?
Java反射原理?

二、JVM

怎么查看Java程序堆的信息

1.Java内存区域

2.内存溢出异常

什么情况下遇到OutOfMemoryError

3.gc算法

JDK1.8默认的垃圾回收器是?HotSpot
新生代大小参数是啥,堆的分类新生代老年代
Full GC发生在什么时候,导致Full GC的原因怎么分析, full gc怎么触发,怎么排查fullgc
高吞吐量的话用哪种gc算法

4.类加载

(1)JVM如何加载类
加载、验证、准备、解析、初始化、使用、卸载
(2)JVM双亲委派模型,为什么要这样做
类加载器:启动类加载器、扩展类加载器、应用类加载器、自定义加载器
类加载机制和类加载的过程:
双亲委派模型的工作过程是:如果一个类加载器收到了类加载的请求,它首先不会自己去尝试加载这个类,而是把这个请求委派给父类加载器去完成,每一个层次的类加载器都是如此,因此所有的加载请求最终都应该传送到最顶层的启动类加载器中,只有当父加载器反馈自己无法完成这个加载请求(它的搜索范围中没有找到所需的类)时,子加载器才会尝试自己去完成加载。
ClassLoader原理和应用

三、多线程/锁/并发

1.线程入门

(1)线程start 、 run方法区别
系统调用线程类的start()方法来启动一个线程,此时该线程处于就绪状态,而非运行状态,也就意味着这个线程可以被JVM来调度执行。在调度过程中,JVM通过调用线程类的run()方法来完成实际的操作,当run()方法结束后,此线程就会终止。
​ 如果直接调用线程类的run()方法,这会被当做一个普通的函数调用,程序中仍然只有主线程这一个线程,也就是说,start()方法能够异步地调用run()方法,但是直接调用run()方法却是同步的,因此也就无法达到多线程的目的。
​ 只有通过调用线程类的start()方法才能真正达到多线程的目的。
(2)进程和线程的区别
进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位。
进程是多个线程的集合。
(3)线程创建方式
五种:1.继承Thread类2.实现Runnable接口3.实现callable接口4.使用匿名内部类5.使用线程池
与继承Thread类的方法相比,使用Runnable接口的方式比较好,面向接口编程,别忘了new Thread(demo类).start()才真的启动线程;
企业上使用线程池的方式创建线程
(4)线程的状态
线程状态?什么时候进入阻塞态什么时候进入等待状态?wait之后的状态可以直接回到Runnable吗
新建、准备/就绪、运行、休眠/阻塞、停止/死亡

新建(new Tread-->就绪(start(),等cpu调度) -->运行--> 死亡(stop或结束)
							/\					|
							 |				   \/				
							休眠(sleep() wait()

(5)守护线程/非守护线程
守护:比如gc线程,和主线程一起销毁
非守护:用户线程,与主线程互不影响。t1.setDaemon(true)设置为守护线程
(6)join()
join()方法A线程里run方法写B.join(),指的是A线程等待B之后再继续执行,A主动让B线程执行

2.线程安全

(1)死锁四个条件
互斥条件:
进程要求对所分配的资源(如打印机)进行排他性控制,即在一段时间内某资源仅为一个进程所占有。此时若有其他进程请求该资源,则请求进程只能等待。
不可剥夺条件:
进程所获得的资源在未使用完毕之前,不能被其他进程强行夺走,即只能由获得该资源的进程自己来释放(只能是主动释放)。
请求与保持条件:
进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已被其他进程占有,此时请求进程被阻塞,但对自己已获得的资源保持不放。
循环等待条件:
存在一种进程资源的循环等待链,链中每一个进程已获得的资源同时被 链中下一个进程所请求。
(2)多线程三大特征
原子性:一致性,保证线程安全问题
可见性
有序性:join,wait,notify(多线程之间通讯)
(3)Java内存模型
主内存(存放共享全局变量)、私有本地内存(本地线程私有变量,存放主内存共享副本)
(3)volatile,volatile的内存语义
volatile的底层如何实现,怎么就能保住可见性了?
保证可见性,不能保证原子性

线程之间的交互方式有哪些?有没有线程交互的封装类 (join)
线程池原理,核心参数,线程池的底层原理和实现方法
线程池有哪些创建方式和安全性问题
有哪些线程池的类型
线程池中LinkedBlockingQueue满了的话,线程会怎么样

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值