2024年Java最新简单总结【java多线程机制】,你花了多久弄明白架构设计

总结

我个人认为,如果你想靠着背面试题来获得心仪的offer,用癞蛤蟆想吃天鹅肉形容完全不过分。想必大家能感受到面试越来越难,想找到心仪的工作也是越来越难,高薪工作羡慕不来,却又对自己目前的薪资不太满意,工作几年甚至连一个应届生的薪资都比不上,终究是错付了,错付了自己没有去提升技术。

这些面试题分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。

大家可以把Java基础,JVM,并发编程,MySQL,Redis,Spring,Spring cloud等等做一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图分享给大家:

希望你看完这篇文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 3、便于线程管理

属性:

corePoolSize:核心池的大小

maximumPoolSize:最大线程数

keepAliveTime:线程没有任务时最多保持多长时间会终止

package improve.threads.threadPool;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

/**

  • @author: Mae.W

  • 使用线程池创建线程

*/

class NumberThread implements Runnable{

@Override

public void run() {

for (int i = 0; i <100 ; i++) {

System.out.println(Thread.currentThread().getName()+“:”+i);

}

}

}

class NumberThread1 implements Runnable{

@Override

public void run() {

for (int i = 0; i >-100 ; i–) {

System.out.println(Thread.currentThread().getName()+“:”+i);

}

}

}

public class ThreadPool {

public static void main(String[] args) {

//1、提供指定线程数量的线程池

ExecutorService executorService = Executors.newFixedThreadPool(10);

//2、执行指定的线程的操作,需要提供实现Runnable接口/Callable接口实现类的对象

executorService.execute(new NumberThread());//适合使用于Runnable

executorService.execute(new NumberThread());//适合使用于Runnable

executorService.execute(new NumberThread1());//适合使用于Runnable

executorService.shutdown();//关闭

/* executorService.submit();//适合使用于Callable*/

}

}

二、多线程的安全问题

共享受限资源

在多线程中,如果两个线程同时使用同一个资源,那么有可能会产生线程安全问题。

例如

//1、创建一个实现Runnable接口的类

class MyThread implements Runnable {

private int num = 10;

//2、实现类去实现Runnable中的抽象方法:run()

@Override

public void run() {

while (true) {

{

if (num > 0) {

System.out.println(Thread.currentThread().getName() + “:” + num);

num–;

} else {

break;

}

}

}

}

}

public class ThreadTest {

public static void main(String[] args) {

//3、创建实现类的对象

MyThread myThread = new MyThread();

//4、将此对象作为参数传递到Thread类的构造器中,创建Thread类对象

Thread t1 = new Thread(myThread);

//5、通过此对象调用start() -->通过Runnable类型的target的run()

Thread t2 = new Thread(myThread);

t1.start();

t2.start();

t1.setName(“线程一”);

t2.setName(“线程二”);

}

}

在此例中,线程一和二共享同一个资源->num,那么此线程就不安全

运行结果:

在这里插入图片描述

我们发现输出语句最后输出了0,而程序代码中 num<=0 就会结束。为什么还会出现0呢?

假设num=1后 线程1进入if语句,但就在此时num还没有减1,所以线程2也进入了if语句 之后num-1 线程2就输出了0

我们还发现输出中有重数,主要是因为我们一个线程满足条件进入了if语句,输出了num,还没有来得及减1,另外一个线程也进入if语句,输出了同样的数。

如何解决线程安全问题呢?

三、解决线程安全问题

1、同步代码块

synchronized(同步监视器){

//需要被同步的代码

}

说明:操作共享数据的代码,即为需要同步的代码

共享数据:多个线程共同操作的变量

同步监视器:俗称,锁;任何一个类的对象都可以充当

要求:多个线程必须要共用同一把锁

在实现Runnable接口创建多线程的方式中,我们可以考虑使用this充当同步监视器

局限性:操作同步代码时,只能有一个线程参与,其他线程等待,相当于是一个单线程的过程,效率低

class MyThread implements Runnable {

private int ticket = 100;

@Override

public void run() {

while (true) {

//this 唯一 是MyThread类的对象 myThread

synchronized (this) {

if (ticket > 0) {

try {

Thread.sleep(50);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + “:卖票:票号” + ticket);

ticket–;

} else {

break;

}

}

}

}

}

public class ThreadTest {

public static void main(String[] args) {

MyThread myThread = new MyThread();

Thread t1 = new Thread(myThread);

Thread t2 = new Thread(myThread);

Thread t3 = new Thread(myThread);

t1.setName(“窗口一”);

t2.setName(“窗口二”);

t3.setName(“窗口三”);

t1.start();

t2.start();

t3.start();

}

}

在这里插入图片描述

可以看出线程安全问题解决了,要特别注意共用同一把锁,否则不起作用

2、同步方法

@Override

public synchronized void run() {

while (true) {

if (ticket > 0) {

try {

Thread.sleep(50);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + “:卖票:票号” + ticket);

ticket–;

} else {

break;

}

}

}

}

错误示例! 我们不能将run方法设置为同步的,因为while循环不是同步数据。

改进:

class MyThread implements Runnable {

private int ticket = 100;

@Override

public synchronized void run() {

while (true) {

show();

}

}

private synchronized void show() { //同步监视器:this

if (ticket > 0) {

try {

Thread.sleep(50);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + “:卖票:票号” + ticket);

ticket–;

}

}

}

将同步语句if写在show方法中,将show方法设置为同步方法

同步方法总结:

  • 非静态的同步方法,同步监视器是this

死锁问题:1、不同的线程分别占用对方所需要的同步资源不放弃,都在等待对方放弃自己所需要的同步资源,形成了线程的死锁

2、出现死锁情况,不会抛异常,也不会出现提示,所以线程都进入阻塞状态,无法继续执行

3、lock锁

class MyThread implements Runnable {

private int ticket = 1000;

//1、实例化ReentrantLock

private ReentrantLock lock = new ReentrantLock();

@Override

public void run() {

while (true) {

try {

//调用锁定方法lock();

lock.lock();

if (ticket > 0) {

System.out.println(Thread.currentThread().getName() + “:” + ticket);

ticket–;

} else {

break;

}

}finally {

//调用解锁方法unlock()

lock.unlock();

}

}

}

}

public class ThreadTest {

public static void main(String[] args) {

MyThread myThread = new MyThread();

Thread t1 = new Thread(myThread);

Thread t2 = new Thread(myThread);

Thread t3 = new Thread(myThread);

t1.start();

t2.start();

t3.start();

}

}

4、synchronized与lock的异同

同:二者都可以解决线程安全问题

不同:synchronized执行完相应的同步代码后,自动地释放同步监视器

lock需要手动启动同步(lock方法)和结束同步(unlock方法)

建议优先使用顺序:lock->同步代码块->同步方法

四、线程通信

线程通信:

例:交替打印

  • 方法:

  • wait():一旦进入此方法,当前线程就会进入阻塞状态,并释放同步监视器

  • notify():一旦执行此方法,就会唤醒被wait的一个线程,如果有多个线程被wait,则唤醒优先级高的线程,若优先级相同则随机唤醒一个

  • notifyAll():一旦执行此方法,就会唤醒所有被wait的线程

  • 说明:

  • 1、这三个方法必须在同步代码块或者同步方法中

  • 2、这三个方法的调用者必须是同步代码块或同步方法中的同步监视器

  • 3、这三个方法定义在Object类中

class MyThread implements Runnable {

private int ticket = 100;

@Override

public void run() {

while (true) {

//this 唯一 是MyThread类的对象 myThread

synchronized (this) {

//唤醒阻塞的所有线程

notifyAll();

if (ticket > 0) {

最后

分享一套我整理的面试干货,这份文档结合了我多年的面试官经验,站在面试官的角度来告诉你,面试官提的那些问题他最想听到你给他的回答是什么,分享出来帮助那些对前途感到迷茫的朋友。

面试经验技巧篇
  • 经验技巧1 如何巧妙地回答面试官的问题
  • 经验技巧2 如何回答技术性的问题
  • 经验技巧3 如何回答非技术性问题
  • 经验技巧4 如何回答快速估算类问题
  • 经验技巧5 如何回答算法设计问题
  • 经验技巧6 如何回答系统设计题
  • 经验技巧7 如何解决求职中的时间冲突问题
  • 经验技巧8 如果面试问题曾经遇见过,是否要告知面试官
  • 经验技巧9 在被企业拒绝后是否可以再申请
  • 经验技巧10 如何应对自己不会回答的问题
  • 经验技巧11 如何应对面试官的“激将法”语言
  • 经验技巧12 如何处理与面试官持不同观点这个问题
  • 经验技巧13 什么是职场暗语

面试真题篇
  • 真题详解1 某知名互联网下载服务提供商软件工程师笔试题
  • 真题详解2 某知名社交平台软件工程师笔试题
  • 真题详解3 某知名安全软件服务提供商软件工程师笔试题
  • 真题详解4 某知名互联网金融企业软件工程师笔试题
  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

资料整理不易,点个关注再走吧

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

名社交平台软件工程师笔试题

  • 真题详解3 某知名安全软件服务提供商软件工程师笔试题
  • 真题详解4 某知名互联网金融企业软件工程师笔试题
  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

[外链图片转存中…(img-u42eO8kS-1714968028330)]

资料整理不易,点个关注再走吧

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 23
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、rocketmq入门到精通视频教程目录大纲 001-001_RocketMQ_简介 002-002_RocketMQ_核心概念详解 003-003_RocketMQ_集群构建模型详解(一) 004-004_RocketMQ_集群构建模型详解(二) 005-005_RocketMQ_双主模式集群环境搭建 006-006_RocketMQ_控制台使用讲解 007-007_RocketMQ_Broker配置文件详解 008-008_RocketMQ_helloworld示例讲解 009-009_RocketMQ_整体架构概述详解 010-010_RocketMQ_Producer_API详解 011-011_RocketMQ_Producer_顺序消费机制详解 012-012_RocketMQ_Producer_事务消息机制详解 013-013_RocketMQ_Consumer_Push和Pull模式及使用详解 014-014_RocketMQ_Consumer_配置参数详解 015-015_RocketMQ_Consumer_重试策略详解 016-016_RocketMQ_Consumer_幂等去重策略详解 017-017_RocketMQ_消息模式及使用讲解 018-018_RocketMQ_双主双从集群环境搭建与使用详解 019-019_RocketMQ_FilterServer机制及使用详解 020-020_RocketMQ_管理员命令 二、rocketmq实战视频教程目录大纲 01_rocketmq_实战项目介绍 02_rocketMQ实战项目设计(一) 03_rocketMQ实战项目设计(二) 04_rocketMQ实战-环境搭建(一) 05_rocketMQ实战-环境搭建(二) 06_rocketMQ实战-生产者与spring结合 07_rocketMQ实战-消费者与spring结合 08_rocketMQ实战-数据库模型设计 09_rocketMQ实战-数据库DAO代码生成 10_rocketMQ实战-远程RPC接口设计与实现(一) 11_rocketMQ实战-远程RPC接口设计与实现(二) 12_rocketMQ实战-远程RPC接口设计与实现(三) 13_rocketMQ实战-下单流程(一) 14_rocketMQ实战-下单流程(二) 15_rocketMQ实战-下单流程(三) 16_rocketMQ实战-下单流程(四) 17_rocketMQ实战-下单流程(五) 18_rocketMQ实战-下单流程(六) 19_rocketMQ实战-下单流程(七) 20_rocketMQ实战-下单流程(八)-商品库存 21_rocketMQ实战-下单流程(九)-商品库存 22_rocketMQ实战-下单流程(十)-支付模块 23_rocketMQ实战-整体联调

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值