博客
关于我
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/

你可能感兴趣的文章
PandoraFMS 监控软件 任意文件上传漏洞复现
查看>>
PanTools多网盘登录神器
查看>>
Papyrus项目常见问题解决方案
查看>>
Parallel.ForEach使用示例
查看>>
Parallel.ForEach的基础使用
查看>>
parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
查看>>
parallelStream导致LinkedList遍历时空指针的问题
查看>>
Parameter ‘password‘ not found. Available parameters are [md5String, param1, username, param2]
查看>>
ParameterizedThreadStart task
查看>>
Paramiko exec_命令的实时输出
查看>>
Spring security之管理session
查看>>
paramiko模块
查看>>
param[:]=param-lr*param.grad/batch_size的理解
查看>>
spring mvc excludePathPatterns失效 如何解决spring拦截器失效 excludePathPatterns忽略失效 拦截器失效 spring免验证拦截器不起作用
查看>>
Spring Cloud 之注册中心 EurekaServerAutoConfiguration源码分析
查看>>
Parrot OS 6.2 重磅发布!推出全新 Docker 容器启动器
查看>>
Parrot OS 6.3 发布!全面提升安全性,新增先进工具,带来更高性能
查看>>
ParseChat应用源码ios版
查看>>
Part 2异常和错误
查看>>
Pascal Script
查看>>