博客
关于我
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相关
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
NFS共享文件系统搭建
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx Location配置总结
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>
nginx 后端获取真实ip
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>
nginx 常用配置记录
查看>>
Nginx 我们必须知道的那些事
查看>>
Nginx 的 proxy_pass 使用简介
查看>>
Nginx 的配置文件中的 keepalive 介绍
查看>>
nginx 配置 单页面应用的解决方案
查看>>
nginx 配置~~~本身就是一个静态资源的服务器
查看>>
Nginx下配置codeigniter框架方法
查看>>