博客
关于我
java并发学习24:固定运行顺序模式
阅读量:313 次
发布时间:2019-03-04

本文共 638 字,大约阅读时间需要 2 分钟。

顺序输出

在并发编程中,wait和notify方法是用来控制线程的等待与通知的。在上面的代码示例中,我们创建了两个线程t1和t2。t1线程会在t2线程运行完成后继续执行。具体来说,t1线程会先等待t2线程的通知,这可以通过lock.wait()实现。当t2线程完成自己的任务后,会设置t2runned为true,并通过lock.notify()将t1线程唤醒,从而确保顺序输出。

park和unpark方法则是用于线程调度的一种机制。park方法会将当前线程暂停,而unpark方法会将其唤醒。这种机制通常用于任务调度或资源管理场景中。

交替输出

在这个设计中,我们使用了wait和notify方法来实现交替输出的功能。通过设置不同的wait和notify标记,我们可以确保线程能够按顺序输出内容。例如,在print方法中,我们会根据当前的wait标记状态等待直到满足条件,然后输出内容并设置下一个标记。这种机制保证了输出的交替性,同时避免了死锁或资源竞争。

await和signal方法则是更高级的替代方案,它们提供了更细粒度的控制。signal方法可以在等待过程中被中断,而await方法则是等待完成的。这种机制在复杂的多线程场景中非常有用,能够提高代码的灵活性和可维护性。

park和unpark方法则是用于线程调度的一种轻量级机制。park方法会将当前线程暂停,而unpark方法会将其唤醒。这种机制在某些特定的场景中非常有用,可以帮助我们更灵活地管理线程的执行顺序。

转载地址:http://sxlq.baihongyu.com/

你可能感兴趣的文章
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS网络文件系统
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>
Nginx + Spring Boot 实现负载均衡
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx - Header详解
查看>>
Nginx Location配置总结
查看>>