多线程知识

多线程

进程和线程的区别

  1. 进程包含线程,一个进程里可以有一个线程,也可以有多个线程

2.进程和线程都是用来实现并发编程的,但是线程比进程更加轻量高效

3.同一个进程的线程之间公用同一份资源,省去了申请资源的开销

4.进程与进程之间是具有独立性的,不会相互影响,线程与线程之间有可能相互影响

5.进程是资源分配的基本单位

线程是调度执行的基本单位

run()和start()有什么区别?

run()方法被称为线程执行体,它的方法体代表了线程需要完成的任务,而start()方法用来启动线程。

说一说sleep()和wait()的区别

  1. sleep()是Thread类中的静态方法,而wait()是Object类中的成员方法;

  2. sleep()可以在任何地方使用,而wait()只能在同步方法或同步代码块中使用;

  3. sleep()不会释放锁,而wait()会释放锁,并需要通过notify()/notifyAll()重新获取锁

Wait() 释放当前锁,让线程进入阻塞,当线程被唤醒时重新获取到锁

说一说Java多线程之间的通信方式

在Java中线程通信主要有以下三种方式:

  1. wait()、notify()、notifyAll()

2.await()、signal()、signalAll()

如果线程之间采用Lock来保证线程安全,则可以利用await()、signal()、signalAll()来实现线程通 信。这三个方法都是Condition接口中的方法

死锁发生条件是什么?

死锁只有同时满足以下四个条件才会发生:

互斥条件:互斥条件是指多个线程不能同时使用同一个资源。

请求保持:持有并等待条件是指,当线程 A 已经持有了资源 1,又想申请资源 2,而资源 2 已经被线程 C 持有了,所以线程 A 就会处于等待状态,但是线程 A 在等待资源 2 的同时并不会释放自己已经持有的资源 1。

不可抢占:不可剥夺条件是指,当线程已经持有了资源 ,在自己使用完之前不能被其他线程获取,线程 B 如果也想使用此资源,则只能在线程 A 使用完并释放后才能获取。

循环等待:环路等待条件指的是,在死锁发生的时候,两个线程获取资源的顺序构成了环形链。

什么是死锁?

死锁是一种非常严重的bug,是说多个线程同时被阻塞,线程中的一个或者多个又或者全部都在等待某个资源被释放,造成线程无限期的阻塞,导致程序不能正常终止

死锁的产生原因

线程1先获取锁A再获取锁B, 线程2先获取锁B再获取锁A, 线程1在获取锁B的时候等待线程2释放B,同时线程2在获取锁A的时候等待线程1释放A

其中最容易破坏的就是循环等待这个条件,那么如何破坏循环等待这个条件呢?

多个线程约定好一定的顺序,按照这个顺序加锁释放锁

如何避免死锁?

避免死锁问题就只需要破环其中一个条件就可以,最常见的并且可行的就是使用资源有序分配法,来破环环路等待条件。

那什么是资源有序分配法呢?线程 A 和 线程 B 获取资源的顺序要一样,当线程 A 是先尝试获取资源 A,然后尝试获取资源 B 的时候,线程 B 同样也是先尝试获取资源 A,然后尝试获取资源 B。也就是说,线程 A 和 线程 B 总是以相同的顺序申请自己想要的资源。

java里面的线程和操作系统的线程一样吗?

Java 底层会调用 pthread_create 来创建线程,所以本质上 java 程序创建的线程,就是和操作系统线程是一样的,是 1 对 1 的线程模型。

相关推荐
眠りたいです2 天前
现代C++:C++11并发支持库
开发语言·c++·多线程·c++11·c++并发支持库
2401_841495643 天前
【自然语言处理】中文文本字频统计与交互式可视化工具
人工智能·python·自然语言处理·多线程·分块读取·文本分析·字频统计
为什么要做囚徒4 天前
并发系列(一):深入理解信号量(含 Redis 分布式信号量)
redis·分布式·多线程·并发编程·信号量
努力发光的程序员5 天前
互联网大厂Java求职面试实录
java·jvm·线程池·多线程·hashmap·juc·arraylist
Da Da 泓5 天前
多线程(四)【线程安全问题】
java·开发语言·jvm·学习·安全·多线程·线程安全问题
Brookty6 天前
Java并发编程核心的基础知识
java·开发语言·java-ee·多线程·线程安全
羑悻的小杀马特8 天前
C++多线程同步工具箱:call_once精准触发、lock_guard/unique_lock智能管理,打造无死锁程序!
c++·多线程·死锁·lock_guard·unique_lock·call_once
武藤一雄9 天前
C# 万字拆解线程间通讯?
后端·微软·c#·.net·.netcore·多线程
萧曵 丶10 天前
CompletableFuture 实际场景使用案例
java·多线程·并发编程·高级开发
萧曵 丶10 天前
CompletableFuture 底层原理详解
java·jvm·多线程·并发编程