首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Linux】深入 Linux 进程等待机制:阻塞阻塞的奥秘

参数: pid: pid=-1,等待任意一个子进程,wait等效。 pid>0,等待其进程IDpid相等的子进程。...sleep(5); exit(257); } else { //father int status = 0; pid_t ret = waitpid(-1,&status,0);//阻塞等待...{ //father int status = 0; pid_t ret = 0; do { ret = waitpid(-1,&status,WNOHANG);//非阻塞等待...3.解释堵塞非堵塞 阻塞场景:打电话等朋友接听 你拨打朋友的电话,直到朋友接通之前你什么都做不了。这就像阻塞调用,你必须等着事情完成。...非阻塞场景:发消息等待回复 你给朋友发了个消息,等他们回你。你不用一直盯着手机看,而是可以去做别的事情,等收到消息后再查看。这就像非阻塞调用,你不需要等着完成才能做其他事情。

9210

多线程并发之CountDownLatch阻塞等待

总结来说,CountDownLatch的作用就是等待其他的线程都执行完任务,必要时可以对各个任务的执行结果进行汇总,然后主线程才继续往下执行。...await(long timeout, TimeUnit unit) 等待timeout时间后,count的值还不是0,不再等待,那么将继续执行 countDown() 使latch的值减1,如果减到了...0,则会唤醒所有等待在这个latch上的线程。...可以用在一些比较耗时长的任务上,例如调用第三方接口、业务线比较长,当超过指定时间后就当作失败处理,避免服务一直处于等待阻塞状态。 结果: 4....扩展 如果采用多线程异步任务Future,通过CompletableFuture.allOf也可以实现同样的效果,阻塞等待任务执行结果,参考文章多线程Future,CompletableFuture

78820
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【多线程】等待唤醒机制和阻塞队列

    ,所以要使用wait,就要先加个锁,阻塞等待就是把自己的锁释放掉再等待,不然一直拿着锁等待,其他线程就没机会了 把wait操作写在synchronized方法里就可以了,运行之后main线程就一直等待中...,在jconsole中看到的也是waiting的状态 注意:wait操作进行解锁和阻塞等待是同时执行的(打包原子),如果不是同时执行就可能刚解锁就被其他线程抢占了,然后进行了唤醒操作,这时原来的线程再去等待...释放锁并进入阻塞等待,准备接收唤醒通知 2....,有的话,厨师进行等待 sleep() 和 wait() 的区别: 这两个方法看起来都是让线程等待,但是是有本质区别的,使用wait的目的是为了提前唤醒,sleep就是固定时间的阻塞,不涉及唤醒,虽然之前说的...阻塞队列的使用 阻塞队列是一种特殊的队列,相比于普通的队列,它支持两个额外的操作:当队列为空时,获取元素的操作会被阻塞,直到队列中有元素可用;当队列已满时,插入元素的操作会被阻塞,直到队列中有空间可以插入新元素

    8610

    同步异步 阻塞阻塞

    而如果我是选择取号等待呢,那么我就坐在沙发上,打电话发短信看书,一心一用,爽哉。 1.2对应技术的问题:           我所选择的排队方式就对应同步异步。...在队伍中等待就是同步,取号等待就是异步。           我在等待过程中,能够进行打电话发短信看书的动作,就是非阻塞。如果在等待过程中,不能够进行打电话发短信看书的动作,那就是阻塞。...2.2同步非阻塞I/O      官方解释:      我的理解:我去银行存钱时,我不得不在队伍中排队等待,但我在等待过程中我还会打电话看书。...2.4 异步非阻塞I/O(AIO)      官方解释:异步非阻塞 I/O 模型是一种处理 I/O 重叠进行的模型。读请求会立即返回,说明 read 请求已经成功发起了。...3.总结      同步异步是一组相对概念,针对的是自己等待还是别人通知      阻塞和非阻塞是一组相对概念,针对的是等待过程中,等待者的操作。

    1.2K20

    Java NIO、BIO、 AIO 同步、阻塞、非阻塞、异步IO 简析

    所谓 同步/异步/阻塞/非阻塞 IO ,是指操作系统中的对 IO 处理的不同方法,而 Java 对这些不同操作方法做了一些包装,由此有了 BIO / NIO / AIO 几种操作接口。...A 处理完之后又把自己阻塞住,等待下一个非空状态。 这样做的坏处是什么呢?就是 E、F、G、H 想在随机时间 往 服务端传文件,建立了连接之后,服务端上面就要有 A、B、C、D 四个线程等着啥也不干。...JDK 实现 IO 最传统的java.io 包下面的 ServerSocket 的写法,只支持阻塞同步。...NIO 普通java.nio 的用法 可以选择同步阻塞模式,和传统 IO 一致 也可以选择同步非阻塞 IO 的实现,底层的话,Windows 下面使用底层的 select ,Linux 下面使用底层的...(比如读取数据库,一般使用同步的方式,如 JDBC 是典型的同步应用),而等待的时间是要占着当前线程的,导致同时处理的任务量过大时,Tomcat 性能非常差。

    35730

    阻塞队列阻塞队列

    使用线程安全队列的场景有很多,Java在实现同步机制时,多线程对竞争资源进行操作时,同一时刻只能有一个线程可以操作,其他线程进行阻塞等待,这时,需要使用一种容器队列来装载等待的线程,在入队和出队时候保证线程的安全性...Java提供两种方式来实现阻塞式和非阻塞式,阻塞式使用锁实现,非阻塞式使用CAS方式实现。使用阻塞队列和非阻塞队列的场景还有很多,比较常用的就是我们常说的生产者\消费者模型。...阻塞队列 Java提供了一个阻塞队列的接口——BlockingQueue,在队列的基础上增加可阻塞添加元素和可阻塞获取元素的方法。 ? ?...阻塞队列是一种线程安全的队列,支持在并发环境下对队列的入队和出队操作,适用于生产者消费者模式,入队线程就是生产者,出队线程就是消费者。...当多个消费者(或生产者)同时进行队列操作时,没有得到锁的线程将被阻塞等待其他线程释放锁,再去竞争锁。

    3.1K30

    Java线程阻塞

    阻塞指的是暂停一个线程的执行以等待某个条件发生(如某资源就绪),学过操作系统的同学对它一 定已经很熟悉了。Java 提供了大量方法来支持阻塞,下面让我们逐一分析。   ...典型地,sleep() 被用在等待某个资源就绪的情形:测试发现条件不满足后,让线程阻塞一段时间后 重新测试,直到条件满足为止。   ...典型地,suspend() 和 resume() 被用在等待另一个线程产生的结果的情形:测试发现结果还没有产生后,让线程阻塞,另一个 线程产生了结果后,调用 resume() 使其恢复。   ...初看起来它们 suspend() 和 resume() 方法对没有什么分别,但是事实上它们是截然不同的。...以上我们对 Java 中实现线程阻塞的各种方法作了一番分析,我们重点分析了 wait() 和 notify() 方法,因为它们的功能最强大,使用也最灵活,但是这也导致了它们的效率较低,较容易出错。

    1.1K10

    同步、异步阻塞、非阻塞

    同步异步   同步和异步关注的是消息通信机制。同步就是在发出一个【调用】时,在没有拿到结果之前,该【调用】就不返回,但是一旦调用返回,就得到返回值了。   ...换句话说,就是由【调用者】主动等待这个【调用】的结果。   而异步正好相反,【调用】在发出之后,这个调用就直接返回了,所以没有返回结果。...同步:执行一个操作之后,等待结果,然后才继续执行后续的操作。   异步:执行一个操作之后,可以去执行其他操作,然后等待通知再回来执行刚才没执行完的操作。 1....阻塞阻塞   阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。   阻塞调用是指调用结果返回之前,当前线程会被挂起,调用线程只有在得到结果之后才会返回。   ...阻塞阻塞是否同步异步无关。 总结: 阻塞:进程给CPU传达一个任务之后,一直在等待CPU处理完成,然后才执行后边的操作。

    2.1K20

    Java阻塞队列

    什么是阻塞队列 原文地址为,转载请注明出处! 阻塞队列是一个支持阻塞的插入和移除的队列。 支持阻塞的插入方法:意思是当队列满时,队列会阻塞插入元素的线程,直到队列不满。...支持阻塞的移除方法:意思是队列为空时,获取元素(同时移除元素)的线程会被阻塞,等到队列变为非空。...阻塞队列 ArrayBlockingQueue:一个由数组结构组成的有界阻塞队列 LinkedBlockingQueue:一个由链表结构组成的有界阻塞队列 PriorityBlockingQueue:一个支持优先级排序的无界阻塞队列...如果队列是空的,消费者会一直等待,当生产者添加元素时,消费者是如何知道当前队列有元素的呢?.../判断 e == null final ReentrantLock lock = this.lock; lock.lockInterruptibly(); //获取锁,lock

    49920

    Java线程之间的通知等待,详解!!

    Java中的Object类是所有类的父类,鉴于继承机制,Java把所有的类都需的方法放在了Object类里面,其中就包含要说的通知等待。...1s后中断了testThread线程,中断后testThread再obj.wait()处抛出了java.lang.InterruptedException 异常而返回并终止。...一个共享变量上可能会有多个线程在等待,具体唤醒哪个等待的线程是随机的。...然后线程C调用notify()方法,尝试唤醒线程,这回激活resourceA的阻塞集合里面的一个线程,这里激活了线程A,所以线程A方法执行完毕并返回了。线程B则继续在阻塞等待中。...因为上边也说过了notifyAll()方法会唤醒共享变量内所有的等待线程。这里就是唤醒了resourceA的等待集合里所有线程。只是线程B先抢到了resourceA上的锁,然后返回。

    1.8K30

    同步异步阻塞阻塞

    | 导语 同步异步阻塞阻塞是开发中经常碰到的概念,但是很多人都没理解清楚,或者混淆了它们的概念。最近看了一些材料,发现以前很多理解都是错的,所以重新整理了一下。...同步异步阻塞阻塞 标题有点简单粗暴,直接用了本文要介绍的几个概念。本来想取个高大上一点的标题,但是感觉主题不那么明了。 好,废话不多说,进入正题。...异步和非阻塞的区别主要在于是否需要等待获取对方状态后再返回。...IO 操作 关于IO操作, 首先说下阻塞阻塞的概念: IO操作的完成往往是需要一定条件的,比如等待可读、可写的,也就是说IO操作很可能是没办法立即完成的。...那么,如果在IO操作没办法立即完成时,不继续往下执行而是等待其完成,则该操作是阻塞的。如果我们不等待,则认为其实非阻塞的。

    1.9K230

    同步、异步阻塞、非阻塞

    通常,同步操作是阻塞的,而异步操作非阻塞,但两对概念也可以交叉组合。 同步异步是基于消息和通信的概念。...异步操作立即返回,操作完成后通知,而同步操作等待操作完成才返回(返回就相当于完成通知,也意味着没有通知)。 阻塞阻塞的最大区别在于,执行操作后资源是否可用(当然是否阻塞也是他们的区别)。...阻塞操作执行后资源可用,非阻塞操作执行后则不一定可用。 例如同步非阻塞,执行语句后就可以做别的,但是资源不可用,没有完成通知,因此需要轮询。...异步阻塞,执行语句后不能做别的,执行下一条语句时资源已经可用了,有完成通知(异步阻塞和同步阻塞只差一个通知,基本没有区别)。

    1.5K10

    同步异步,阻塞和非阻塞

    Java 中的 BIO、NIO 和 AIO 可以理解为是 Java 语言对操作系统的各种 IO 模型的封装。...在使用这些 API 的时候,不需要关心操作系统层面的知识,也不需要根据不同操作系统编写不同的代码,只需要使用 Java 的 API 就可以了。...在讲 BIO,NIO,AIO 之前,先来回顾一下这样几个概念:同步异步,阻塞阻塞。...同步和异步的最大区别,在于异步的话调用者不需要等待处理结果,被调用者会通过回调等机制来通知调用者其返回结果。...阻塞和非阻塞 阻塞阻塞就是发起一个请求,调用者一直等待请求结果返回,也就是当前线程会被挂起,无法从事其他任务,只有当条件就绪时才能继续; 非阻塞: 非阻塞就是发起一个请求,调用者不用一直等着结果返回

    1.2K20

    Java同步和异步,阻塞和非阻塞

    阻塞和非阻塞属于进程API执行动作的方式, 关注的是程序在等待调用结果时的状态. 阻塞是指: 调用结果返回之前, 当前线程会被挂起. 函数只有在得到结果之后才会返回, 线程需要等待结果....非阻塞是指: 阻塞的概念相对应, 指在不能立刻得到结果之前, 该函数不会阻塞当前线程, 而会立刻返回. 线程不需要等待结果....Java中的同步和异步 定义: 任务A, 任务B 同步: 任务A和任务B之间有关联, 例如任务B中途要给任务A一个数字, 那么任务A或许需要等待任务B生产这个数, 任务A需要等待任务B的这个动作叫做同步...定义: 线程A和线程B, 分别在执行任务A和任务B 阻塞: 线程A需要等待线程B, 于是线程A在等待这个数的步骤上被挂起, 不能分到cpu, 不能执行, 这样被称为阻塞....下面给出Java代码的例子. 同步阻塞: int i = System.in.read(); 当命令终端没有输入时, 调用该方法的线程被阻塞 ,表现出和终端同步.

    5.5K31

    selenium 的显示等待隐式等待

    driver.find_elements_by_tag_name("input") element = driver.find_element_by_xpath("//input[@id='passwd_id']") 页面交互...直接找到我们要抓取的tag或者直接没有等待元素出来就开始交互导致不起作用的问题。...selenium的页面等待有显示等待和隐式等待 隐式等待 比较简单,提供一个等待时间,单位为秒,则等这个时间过去在去做其他操作。...driver.implicitly_wait(10),如果不设置默认为0 显示等待 指定某个条件,然后设置最长等待时间。如果在这个时间还没有找到元素,那么便会抛出异常。...driver:浏览器驱动 timeout:最长超时等待时间 poll_frequency:检测的时间间隔,默认为500ms ignore_exception:超时后抛出的异常信息,默认情况下抛

    3.6K40

    socket阻塞阻塞,同步异步、IO模型

    阻塞和非阻塞是指当server端的进程访问的数据如果尚未就绪,进程是否需要等待,简单说这相当于函数内部的实现区别,也就是未就绪时是直接返回还是等待就绪; 而同步和异步是指client端访问数据的机制,...同步一般指主动请求并等待I/O操作完毕的方式,当数据就绪后在读写的时候必须阻塞(区别就绪读写二个阶段,同步的读写必须阻塞),异步则指主动请求数据后便可以继续处理其它任务,随后等待I/O,操作完毕的通知...阻塞I/O模型: 简介:进程会一直阻塞,直到数据拷贝完成 应用程序调用一个IO函数,导致应用程序阻塞等待数据准备好。...较好的做法是,使用套接字的“I/O模型”来判断非阻塞套接字是否可读可写。 非阻塞模式套接字阻塞模式套接字相比,不容易使用。...但低效也是相对的,视情况而定,也可通过良好的设计改善 同步/异步阻塞/非阻塞经常看到是成对出现: 同步阻塞,异步非阻塞,同步非阻塞

    2K20

    socket阻塞阻塞,同步异步、IO模型

    阻塞和非阻塞是指当server端的进程访问的数据如果尚未就绪,进程是否需要等待,简单说这相当于函数内部的实现区别,也就是未就绪时是直接返回还是等待就绪; 而同步和异步是指client端访问数据的机制,同步一般指主动请求并等待...I/O操作完毕的方式,当数据就绪后在读写的时候必须阻塞(区别就绪读写二个阶段,同步的读写必须阻塞),异步则指主动请求数据后便可以继续处理其它任务,随后等待I/O,操作完毕的通知,这可以使进程在数据读写时也不阻塞...阻塞I/O模型: 简介:进程会一直阻塞,直到数据拷贝完成 应用程序调用一个IO函数,导致应用程序阻塞等待数据准备好。...如果要同时响应成百上千路的连接请求,则无论多线程还是多进程都会严重占据系统资源,降低系统对外界响应效率,而线程进程本身也更容易进入假死状态。 由此可能会考虑使用“线程池”或“连接池”。...较好的做法是,使用套接字的“I/O模型”来判断非阻塞套接字是否可读可写。 非阻塞模式套接字阻塞模式套接字相比,不容易使用。

    2.7K30

    聊聊同步异步、阻塞阻塞、IO模型

    程序员:如果必须等待A完成后才能执行B那么这个就是阻塞的,如果A,B可以同时执行那么就 是非阻塞的 面试官:那你的意思异步/同步的概念阻塞阻塞一样了? 程序员:嗄。。。可以这么说吧。...)被调用者通过状态、通知或回调机制主动通知调用者被调用者的运行状态 阻塞/非阻塞 阻塞/非阻塞:关注调用者在等待结果返回之前所处的状态 阻塞:(blocking),指IO操作需要彻底完成后才返回到用户空间...同步体现在:等待下载完成通知; 阻塞体现在:等待下载完成通知过程中,不能做其他任务处理; 2. 非阻塞型 ? 同步非阻塞IO模型 描述: 用户线程发起IO请求时立即返回。...同步体现在:等待下载完成通知; 非阻塞体现在:等待下载完成通知过程中,去干别的任务了,只是时不时会瞄一眼进度条;【小明必须要在两个任务间切换,关注下载进度】 3. 复用型 ?...异步IO模型 描述: 异步IO信号驱动IO最主要的区别是信号驱动IO是由内核通知何时可以进行IO操作,而异步IO则是由内核告诉我们IO操作何时完成了。

    1.2K10
    领券