100+家公司的JAVA面试八股文,终于整理完了

本文整理了100+道互联网大厂JAVA面试常见问题,涵盖并发编程、线程池、同步工具类等多个核心知识点。通过学习,可以帮助开发者深入理解JAVA基础,提升面试竞争力。内容包括并发编程三要素、线程状态流转、线程池的创建与优点、synchronized与volatile的区别、乐观锁与悲观锁的概念等,适合程序员面试复习与日常技术巩固。
摘要由CSDN通过智能技术生成

前言

又是一年面试跳槽季,你准备好了吗?
今天为大家整理了目前互联网出现率最高的大厂面试题,所谓八股文也就是指文章的八个部分,文体有固定格式:由破题、承题、起讲、入题、起股、中股、后股、束股八部分组成,题目一律出自四书五经中的原文。
而JAVA面试八股文也就是为了考验大家的JAVA基础功底,所以强烈建议背诵全文!
在这里插入图片描述

提示:以下为互联网面试中最常见JAVA基础面试题整理

白嫖学习资料←戳我

正文

1、并发编程三要素?

(1) 原子性
原子性指的是一个或者多个操作,要么全部执行并且在执行的过程中不被其他操作打断,要 么就全部都不执行。

(2) 可见性
可见性指多个线程操作一个共享变量时,其中一个线程对变量进行修改后,其他线程可以立 即看到修改的结果。

(3) 有序性
有序性,即程序的执行顺序按照代码的先后顺序来执行。

2、实现可见性的方法有哪些?

synchronized 或者 Lock:保证同一个时刻只有一个线程获取锁执行代码,锁释放之前把最新的值刷新到主内存,实现可见性。

3、多线程的价值?

(1) 发挥多核 CPU 的优势
多线程,可以真正发挥出多核 CPU 的优势来,达到充分利用 CPU 的目的,采用多线程的方式去同时完成几件事情而不互相干扰。

(2) 防止阻塞
从程序运行效率的角度来看,单核 CPU 不但不会发挥出多线程的优势,反而会因为在单核CPU 上运行多线程导致线程上下文的切换,而降低程序整体的效率。但是单核 CPU 我们还是要应用多线程,就是为了防止阻塞。试想,如果单核 CPU 使用单线程,那么只要这个线程阻塞了,比方说远程读取某个数据吧,对端迟迟未返回又没有设置超时时间,那么你的整个程序在数据返回回来之前就停止运行了。多线程可以防止这个问题,多条线程同时运行, 哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。

(3) 便于建模
这是另外一个没有这么明显的优点了。假设有一个大的任务 A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务 A 分解成几个小任务,任务 B、任务 C、任务 D,分别建立程序模型,并通过多线程分别运行这几个任务,那就简单很多了。

4、创建线程的有哪些方式?

(1) 继承 Thread 类创建线程类

(2) 通过 Runnable 接口创建线程类

(3) 通过 Callable 和 Future 创建线程

(4) 通过线程池创建

5、创建线程的三种方式的对比?

(1) 采用实现 Runnable、Callable 接口的方式创建多线程。优势是:

线程类只是实现了 Runnable 接口或 Callable 接口,还可以继承其他类。在这种方式下,多个线程可以共享同一个 target 对象,所以非常适合多个相同线程来处理同一份资源的情况, 从而可以将 CPU、代码和数据分开,形成清晰的模型,较好地体现了面向对象的思想。

劣势是:

编程稍微复杂,如果要访问当前线程,则必须使用 Thread.currentThread()方法。

(2) 使用继承 Thread 类的方式创建多线程优势是:

编写简单,如果需要访问当前线程,则无需使用 Thread.currentThread()方法,直接使用 this
即可获得当前线程。劣势是:
线程类已经继承了 Thread 类,所以不能再继承其他父类。

(3) Runnable 和 Callable 的区别
1、Callable 规定(重写)的方法是 call(),Runnable 规定(重写)的方法是 run()。2、Callable 的任务执行后可返回值,而 Runnable 的任务是不能返回值的。
3、Call 方法可以抛出异常,run 方法不可以。

4、运行 Callable 任务可以拿到一个 Future 对象,表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。通过 Future 对象可以了解任务执行情况,可取消任务的执行,还可获取执行结果。

6、线程的状态流转图

线程的生命周期及五种基本状态:
在这里插入图片描述

7、Java 线程具有五中基本状态

(1) 新建状态(New):
当线程对象对创建后,即进入了新建状态,如:Thread t= new MyThread();

(2) 就绪状态(Runnable):
当调用线程对象的 start()方法(t.start();),线程即进入就绪状态。处于就绪状态的线程, 只是说明此线程已经做好了准备,随时等待 CPU 调度执行,并不是说执行了 t.start()此线程立即就会执行;

(3)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值