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

【JUC基础】07. wait(),notify()虚假唤醒

1、什么是wait和notify 属于Object类的两个方法。 wait(),使当前线程等待,直到另一个线程使用notify()或notifyAll()方法唤醒。...notify(),唤醒正在wait等待的线程。...什么是虚假唤醒:是不想唤醒它或者说不确定是否应该唤醒,但是被唤醒了。...对程序来说,wait 方法应该卡住当前程序,不应该往后执行;但是实际上并没有被卡住,而是在非预期的时间程序正常执行了,没有程序没有被卡住就是被虚假唤醒了 5、结论 在if条件判断下,他只会判断一次,如果这时候被...而如果使用while判断,唤醒后会重新执行while循环条件。如果条件成立,就继续wait。因此就出现了上面看到的现象。 好了,又白嫖了一个无聊的小知识,没用但有趣的小知识。

15410

一文看懂wait和notify的虚假唤醒(spurious wakeups)

一个线程执行了 wait 方法以后,它不会再继续执行了,直到被 notify 唤醒。 那么唤醒以后从何处开始执行? 这是解决这里出错原因的关键。 我们尝试修改代码,实现一个生产线程,两个消费线程。...结论:就是用 if 判断的话,唤醒后线程会从 wait 之后的代码开始运行,但是不会重新判断 if 条件,直接继续运行 if 代码块之后的代码,而如果使用 while 的话,也会从 wait 之后的代码运行...,但是唤醒后会重新判断循环条件,如果不成立再执行 while 代码块之后的代码块,成立的话继续 wait。...用 while 而不是 if 来判断,可以避免虚假唤醒。是因为操作系统的通知不可信,自己再校验一次,如果是虚假唤醒就再 wait 一次(直到正确为止)。...被唤醒的消费者线程由于已经使用了 while 进行优化,会执行 wait 操作释放锁并加入等待池。

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

    ubuntu linux下开启远程唤醒

    目录 启动远程唤醒,需要主板支持才能进行。 步骤一:检查计算机硬件是否支持WOL(wake on lan)功能。...步骤二:检查主板和电源是否支持WOL 步骤三:检查网卡是否支持WOL 步骤四:查看网卡 步骤五:查询网卡是否支持远程唤醒 步骤六:开启远程唤醒 d为关闭g为开启 步骤七:参考操作 启动远程唤醒,需要主板支持才能进行...Wake On Lan模式可以在完全关机状态下唤醒,而Wake On PCI Card模式要在深度休眠状态下唤醒。...步骤三:检查网卡是否支持WOL 安装ethtool,并执行以下命令: sudo apt-get install ethtool 步骤四:查看网卡 步骤五:查询网卡是否支持远程唤醒 sudo...在本地计算机上安装远程唤醒工具wakeonlan: sudo apt-get install wakeonlan 小结2:唤醒远程计算机 执行下面的命令就可以唤醒远程的计算机了: #host_address

    10.9K10

    linux 主机支持远程唤醒_Linux远程开机

    先不要急着去关闭你的linux服务器,你首先要确定它是否支持远程开机?...则下次开机后会自动执行 第二个: 编辑/etc/sysconfig/network-scripts/ifcfg-eth0 (eth0网卡的配置文件),添加上一行: ETHTOOL_OPTS=”wol g” 4,网络唤醒的局限性...因为机器关闭后,完全是靠网卡唤醒机器,此时的机器是关闭的,没有操作系统运行, 也就谈不上支持tcp/ip协议,当然也就不能通过互联网运行了....我们必须能登录到局域网中的一台机器上,在此机器上运行wake on lan 去唤醒目标机器 前提条件就是:目标机器和我们登录的机器在同一局域网中 5,还有一点:被远程开机的目标机器必须是插电的,没插电源的机器也能开机只有电影中才会出现...下面简单介绍一下linux下的wakeonlan的用法: 假设远程要唤醒的计算机IP:12.34.56.78,Mac地址:01:02:03:04:05:06 $ wakeonlan -i 12.34.56.78

    11.6K30

    java:用CountDownLatch.await替代Object.wait实现线程阻塞唤醒

    下面的代码利用传统的Object.wait()/nofity()方法来实现: public void openSource() { // 创建一个初值为1的倒数计数器对象作为通知对象...start(); synchronized (notifier){ try { // 启动子线程后立即阻塞, 等待被子线程唤醒...notifier.wait(); } catch (InterruptedException e) {} } /...} 话说,用Object.wait()/notify()倒是挺直观,但是,这synchronized同步块代码写起来实在有点啰嗦,我是个一行代码都不想多写的懒人。...当然相比原始的wait/nofity,CountDownLatch的实现是经过高度封装的代码,最终它也是用wait/nofity来实现的,但逻辑更复杂,所以性能上有多少影响我并不清楚,因为我的应用环境是在程序初始化的时候

    89420

    Linux小课堂之Wait命令

    wait是一个shell命令,它等待给定进程完成,然后返回其退出状态。 Wait命令用于等待特定的进程ID和作业ID并返回其终止状态。...-wait PID(PID-实用程序要等待终止的命令的进程ID)。-wait JID(JID-作业ID,标识要等待的后台进程,仅适用于当前Shell执行环境中的wait调用)。...如果wait命令检测到任何错误,那么它将返回1到126之间的任何值。如果最后一个进程ID是未知的,则wait命令将以值127退出。...Wait命令示例 让我们检查一些脚本以了解wait命令的工作方式。 示例1 –带有Wait命令的脚本 我们有两个脚本,分别称为“ foo.sh”和“ bar.sh”脚本。...结论 Wait和Sleep都是操作系统中基于时间的系统调用。 我们来看一下wait和sleep命令之间的区别。 ?

    2.3K20

    Linux僵尸进程以及wait函数

    Linux下使用top命令可以查看当前进程数目,以及进程的状态。例如: 可以看到我的系统暂时并没有僵尸进程(zombie) 。挂起的进程倒是一大堆。...僵尸进程产生的原因:每个Linux进程在进程表中都有一个进入点,内核执行该进程时,使用到的一切信息都存入在进程点。我们可以使用ps命令来查看进程状态。...但是子进程的回收仍旧需要父进程来做,好处是不用使用wait()来挂起了,父进程可以忙自己的。 使用wait函数和waitpid函数。...wait函数:需要头文件#include 函数原型:pid_t wait(int *status); 函数功能:阻塞(睡眠)进程,等待子进程结束,负责为子进程回收资源。...下面的例子指出了如何使用带参数的wait函数。

    1.7K10

    深入理解Linux内核之进程唤醒

    1.开场白 环境: 处理器架构:arm64 内核源码:linux-5.10.50 ubuntu版本:20.04.1 代码阅读工具:vim+ctags+cscope 前面文章,我们介绍了进程是如何睡眠,本文来揭开进程唤醒的神秘面纱...应用场景 进程唤醒主要应用场景如下: fork的时候唤醒子进程 exec的时候唤醒进程 睡眠超时唤醒 睡眠锁释放唤醒 IO读写完成唤醒 其他正常的唤醒路径 注:应用场景在此不再分析,感兴趣的小伙伴可以自行查阅内核源代码...-> p->state = TASK_RUNNING; //设置运行状态 进程唤醒的主要调用链如上:会唤醒特定状态的进程(wake_up_process唤醒三种睡眠状态的进程,睡眠文章已经讲到...,会做一些基本的判断,如唤醒进程是否是运行队列当前进程、是否已经设置了重新调度标志、抢占idle进程处理等,然后调整唤醒进程的调度实体和运行队列当前进程调度实体在同一层次任务组中,最后进行关键的唤醒抢占条件判断...将唤醒进程加入到目标cpu的运行队列,这里会调用到调度enqueue_task回调,如加入cfs的红黑树。 唤醒抢占处理,被唤醒的高优先级进程可以抢占当前进程。

    3K20

    唤醒词_好听的唤醒

    这里要注意,检测的“实时性”是一个关键点,语音唤醒的目的就是将设备从休眠状态激活至运行状态,所以唤醒词说出之后,能立刻被检测出来,用户的体验才会更好。 那么,该怎样评价语音唤醒的效果呢?...通行的指标有四个方面,即唤醒率、误唤醒、响应时间和功耗水平: ➤唤醒率,指用户交互的成功率,专业术语为召回率,即recall。...➤误唤醒,用户未进行交互而设备被唤醒的概率,一般按天计算,如最多一天一次。 ➤响应时间,指从用户说完唤醒词后,到设备给出反馈的时间差。 ➤功耗水平,即唤醒系统的耗电情况。...第三类是基于端到端的方案,输入语音,输出为各唤醒的概率,一个模型解决。 语音唤醒的难点 语音唤醒的难点,主要是低功耗要求和高效果需求之间的矛盾。...➤Zero-shot:将常用用户指定设置为唤醒词,达到用户无感知唤醒,例如直接对车机说“导航到科大讯飞”,这里将一些高频前缀的说法设置成唤醒词。

    1.2K10

    linux系统查看网卡是否支持WOL网络唤醒并开启WOL唤醒功能

    硬件开启了网络唤醒功能,接下来就需要在系统里设置了。 检查是否开启WOL唤醒功能 linux检查网卡是否支持唤醒功能,输入命令命令打印出网卡的信息。...d -- 禁用 p -- 物理活动唤醒 u -- 单播消息唤醒 m -- 多播(组播)消息唤醒 b -- 广播消息唤醒 a -- ARP 唤醒 g -- 特定数据包magic packet唤醒 s --...设有密码的特定数据包magic packet唤醒 然后看Wake-on的值,若为g,表示网卡已开启远程唤醒功能; 开启WOL唤醒功能 若为d,则需要输入命令开启。...为什么这里选择的g,因为其他只是单纯的唤醒,并没有验证,可能路由器的一个广播操作都会将电脑给唤醒,g为特定数据包magic packet唤醒唤醒的时候是发送一段特殊的代码,进行操作。...幻数据包(Magic Packet) 由 AMD 公司提出,幻数据包是一个广播帧,包含待唤醒计算机的MAC地址。

    7.5K20

    Linuxwait, WIFEXITED, WEXITSTATUS的比较

    偶尔翻到了这几个关键字,找到个文章复习了下: “http://www.ibm.com/developerworks/cn/linux/kernel/syscall/part3/” 。...记录下: wait的函数原型是: #include /* 提供类型pid_t的定义 */ #include pid_t wait(int...*status) 进程一旦调用了wait,就立即阻塞自己,由wait自动分析是否当前进程的某个子进程已经退出,如果让它找到了这样一个已经变成僵尸的子进程,wait就会收集这个子进程的信息...,并把它彻底销毁后返回;如果没有找到这样一个子进程,wait就会一直阻塞在这里,直到有一个出现为止。...); 如果成功,wait会返回被收集的子进程的进程ID,如果调用进程没有子进程,调用就会失败,此时wait返回-1,同时errno被置为ECHILD。

    1.2K40

    linux0.11进程睡眠唤醒原理分析

    TASK_INTERRUPTIBLE状态的进程可以被wake_up和信号唤醒唤醒的时候也是通过修改进程的状态为可运行,然后等待下一次进程调度,被唤醒的进程不一定马上得到执行。...,wake_up会唤醒链表的第一个 睡眠节点,因为第一个节点里保存了后面一个节点的地址,所以他唤醒后面一个节点, 后面一个节点以此类推,从而把整个链表的节点唤醒,这里的实现类似...*/ tmp = *p; *p = current; // 不可中断睡眠只能通过wake_up唤醒,即使有信号也无法唤醒 current->state = TASK_UNINTERRUPTIBLE...,不可中断的时候, 能保证唤醒的时候,是从前往后逐个唤醒,但是可中断睡眠无法保证这一点, 因为进程可能被信号唤醒了,所以需要判断全局指针是否指向了自己,即自己插入 链表后,还有没有进程也插入了该链表...wake_up能保证唤醒的是第一个节点, 这里先唤醒链表中比当前进程后插入链表的节点,有点奇怪,自己被信号唤醒了, 去唤醒别的进程,自己却还睡眠 */ if

    2.3K40
    领券