# Java中的阻塞与等待:区别与应用
在Java并发编程中,理解“阻塞”(Blocking)和“等待”(Waiting)的区别是十分重要的。这两种状态在多线程环境下常常被混淆,但实际上它们指的是不同的线程状态和行为。在这篇文章中,我们将详细分析这两者的区别,并通过代码示例进行说明。
## 1. 概念解释
在Java中,线程的状态可以是多种多样的,其中最常见的状态包括:
- **阻塞状态**
挂起:一般是主动的,由系统或程序发出,甚至于辅存中去。(不释放CPU,可能释放内存,放在外存)阻塞:一般是被动的,在抢占资源中得不到资源,被动的挂起在内存,等待某种资源或信号量(即有了资源)将他唤醒。(释放CPU,不释放内存)另外,有一段话很形象: 首先这些术语都是对于线程来说的。对线程的控制就好比你控制了一个雇工为你干活。你对雇工的控制是通过编程来实现的。挂
转载
2024-01-21 07:31:58
105阅读
了解线程的状态,1. 新建状态(New) : 线程对象被创建后,就进入了新建状态。2. 就绪状态(Runnable): 也被称为“可执行状态”。线程对象被创建后,其它线程调用了该对象的start()方法,从而来启动该线程。例如,thread.start()。处于就绪状态的线程,随时可能被CPU调度执行。3.&nb
转载
2024-06-05 10:34:34
86阅读
概括的解释下线程的几种状态就绪(Runnable):线程准备运行,不一定立马就能开始执行。运行中(Running):进程正在执行线程的代码。等待中(Waiting):线程处于阻塞的状态,等待外部的处理结束。睡眠中(Sleeping):线程被强制睡眠。I/O阻塞(Blocked on I/O):等待I/O操作完成。同步阻塞(Blocked on Synchronization):等待获取锁。死亡(D
面试问题——阻塞和等待状态的区别阻塞等待TIMED_WAITING 阻塞Java 文档将BLOCKED状态正式定义为:“被阻塞等待监视器锁的线程处于此状态。”现实生活中的例子:今天你要去面试。这是您梦想中的工作,这是您过去几年的目标。你一大早醒来,做好准备,穿上你最好的衣服,在镜子前看起来很锐利。现在你走出车库,意识到你的妻子已经把车开走了。在这种情况下,你只有一辆车,那会发生什么?在现实生活中
转载
2024-05-14 12:41:56
26阅读
线程状态: 线程共包括以下5种状态。
1. 新建状态(New)
线程对象被创建后,就进入了新建状态。例如,Thread thread = new Thread()。
2. 就绪状态(Runnable)
也被称为“可执行状态”。线程对象被创建后,其它线程调用了该对象的start()方法,从而来启动该线程。
例如,thread.start()。处于就绪状态的线程,随时
转载
2024-02-18 20:57:20
22阅读
对于发生一次网络IO,可以分为两部分:1、等待数据: 阻塞:线程一直阻塞等待数据。 非阻塞:线程发送请求后,不等待数据,通过轮询/信号量等方式去获取数据是否准备好。2、将数据从内核复制到用户空间: 同步:线程自己把数据从内核复制到用户空间,期间不能做其它事情,一直等待数据复制完毕。
Java NIO 学习总结(二)主要内容: 1.阻塞与非阻塞 1.阻塞与非阻塞 2.DatagramChannel一、阻塞与非阻塞 阻塞:客户端请求服务端时,读写请求不能及时处理时,服务端处理线程与客户端请求线程就会处于占用(等待)的阻塞状态; &n
转载
2023-10-10 22:02:20
69阅读
我们在做Java socket编程时,有时候为了方便会选择使用buffereader进行头部信息的处理。但有时候也会遇到一些问题。比如标题所说的阻塞问题。for example:1 BufferedReader br;
2
3 while (line != null) {
4 line = br.readLine();
5 } 这样循环读的话,当到达最后一行
转载
2023-06-12 18:10:57
249阅读
由于多个进程在并发执行时共享系统资源,致使它们在运行过程中呈现间断性的运行规律,所以进程在其生命周期内可能具有多种状态。一、进程的三种基本状态 1. 就绪状态(Ready)进程已分配到除CPU之外的所有必要资源,只要再获得CPU,便可立即执行。 2. 执行状态 (Running)进程已获得CPU,正在执行。(多处理机系统中,则有多个进程处于执行状态) 3. 阻塞状态(Block / Waiting
假设您询问Thread.State.BLOCKED和Thread.State.WAITING状态之间的区别(即,由t.getState()返回)?I want to know what is the difference on jvm level and what difference on the CPU从下到上,硬件级别没有区别,因为这些状态不是硬件概念. WAITING线程和BLOCKED线
转载
2023-10-21 20:46:41
43阅读
了解线程的状态,1. 新建状态(New) : 线程对象被创建后,就进入了新建状态。2. 就绪状态(Runnable): 也被称为“可执行状态”。线程对象被创建后,其它线程调用了该对象的start()方法,从而来启动该线程。例如,thread.start()。处于就绪状态的线程,随时可能被CPU调度执行。3.&nb
转载
2023-08-04 17:59:07
59阅读
进程的三种状态1. 就绪状态:进程获得了除了CPU之外的所有的必要资源,只要获得CPU就可以立即执行,此时的进程处于就绪态。2. 运行状态:进程已经获得CPU,正在运行,在多处理其系统中,会有多个进程同时处于运行状态。3. 阻塞状态:处于执行状态的进程由于发生某些事件而暂时无法继续执行,放弃处理机
转载
2024-01-27 22:52:59
163阅读
java NIO 和阻塞I/O的区别 1. 阻塞I/O通信模型 假如现在你对阻塞I/O已有了一定了解,我们知道阻塞I/O在调用InputStream.read()方法时是阻塞的,它会一直等到数据到来时(或超时)才会返回;同样,在调用ServerSocket.accept()方法时,也会一直阻塞到有客户端连接才会返回,每个客户端连接过来后,服务端都会启动一个线程去处理该客户端的请求。
转载
2024-06-20 06:49:50
25阅读
阻塞队列阻塞队列(BlockingQueue)是一个支持两个附加操作的队列。这两个附加的操作是:在队列为空时,获取元素的线程会等待队列变为非空。当队列满时,存储元素的线程会等待队列可用。阻塞队列常用于生产者和消费者的场景,生产者是往队列里添加元素的线程,消费者是从队列里拿元素的线程。阻塞队列就是生产者存放元素的容器,而消费者也只从容器里拿元素。[外链图片转存失败,源站可能有防盗链机制,建议将图片保
转载
2023-11-27 19:14:43
87阅读
一.进程具有三种基本状态就绪状态。某些进程“万事俱备”(必要资源),只差CPU。(就绪队 列)执行状态。某进程占有CPU并在CPU上执行其程序。阻塞状态。某些进程由于某种原因不能继续运行下去,等待处 理问题。也称为等待状态或封锁状态。如:请求I/O。(多个等待队列)三种状态随着执行和条件的变化而发生转换:二.进程状态转换的原因1. 就绪-→执行: 对就绪状态的进程,当进程调度程序按一种选定的策略从
转载
2023-11-06 13:22:32
57阅读
你可能已经听说Node.js是“基于Chrome的V8 JavaScript引擎的异步JavaScript运行的”,并且它“使用事件驱动的非阻塞I / O模型,使其轻量级和高效”。但对某些人来说,这不是最好的解释,或许太过于概念化。首先要了解什么是Node.js?其次要知道Node.js究竟“异步”与“同步”有什么不同意思?还要讨论,“事件驱动”和“非阻塞”的含义是什么?什么是Node.jsNod
转载
2023-12-21 12:46:02
42阅读
原标题:一篇文章带你彻底搞懂NIO什么是NIOJava NIO (New IO)是 Java 的另一个 IO API (来自 java1.4) ,意味着可以替代标准的 Java IO API和 Java Networking API。提供了一种与标准 IO API 不同的 IO 工作方式。注意:Java的NIO只是说IO API,阻塞非阻塞才是IO的模型。也有人称NIO为No-Blocking I
# Java线程等待和阻塞的区别
## 引言
在Java开发中,线程是实现并发编程的重要工具。线程的等待和阻塞是常见的线程操作,但对于刚入行的小白来说,可能会对它们的区别感到困惑。本文将解释Java线程等待和阻塞的概念并提供具体的代码示例,帮助小白更好地理解和应用它们。
## 流程
下面是Java线程等待和阻塞的整体流程:
```mermaid
flowchart TD
subgra
原创
2023-09-02 08:02:23
217阅读
一、概述 从图中可以看出,线程的状态大致可分为5种,NEW、RUNNABLE、RUNNING、BLOCKED、TERMINATED。可能读者会感到疑惑,为什么没有等待状态,其实大家可以不必刻意去区分等待状态和阻塞状态,只需要弄清楚二者的区别即可。 等待状态的定义:处于这种状态的线程无限期地等待另一个线程执行特定操作。 阻塞状态的定义:一个线程因为等待临界区的锁被阻塞产生的状态。 我们可以看出二者的
转载
2023-08-10 20:00:04
644阅读