当前位置: 首页 > 面试题库 >

Java中的跨进程同步

叶炜
2023-03-14
问题内容

如何同步运行Windows上的两个Java进程?

我正在寻找类似Win32 Named Mutex对象的对象,该对象允许两个进程使用相同的锁定对象。

谢谢


问题答案:

在Java中无法完成所需的操作。不同的Java应用程序将使用不同的JVM,将它们完全分隔成不同的“黑匣子”。但是,您有2个选择:

  1. 使用插座(或通道)。基本上,一个应用程序将打开侦听套接字并开始等待,直到它接收到一些信号为止。另一个应用程序将在那里连接,并在完成某些操作后发送信号。我想说这是99.9%的应用程序中首选的方式。
  2. 您可以从Java调用winapi。我不记得具体细节,但是如果您使用Google“ java winapi”,则可以找到很多示例。


 类似资料:
  • 本文向大家介绍Solaris中的进程同步,包括了Solaris中的进程同步的使用技巧和注意事项,需要的朋友参考一下 Solaris实现了各种锁来支持多任务,多线程和多处理。它使用自适应互斥锁,条件变量,信号量,读写锁,旋转栅门来控制对关键部分的访问。 一个自适应互斥使用用于保护仅由短代码段访问每一个关键数据项。 在多处理器系统上,它以标准信号量自旋锁开始。如果锁由正在另一个CPU上运行的线程持有,

  • 概览 Chromium有一个多进程架构,这意味着我们有许多需要互相交流的进程。我们的主要跨进程交流元素是命名管道。在Linux和OS X上,我们使用socketpair()。每个渲染器进程可以分配到一个命名管道来跟浏览器进程交流。这些管道是用异步方式使用的,确保没有哪个端会等待另一个端。 想要得到如何编写安全的IPC端点的知识,请查看IPC安全要点. 浏览器中IPC 在浏览器中,与渲染器的交流是通

  • 如何在将GUI保持为活动状态而不是Hibernate/等待状态的同时延迟进程或创建队列?

  • 1-工序A N-过程B 我有1个A进程和N个B进程。进程将A数组的元素写入共享变量x。然后所有N个B个进程都必须读取数据并将其存储到本地数组中。当所有的N B进程都存储它时,那么一个进程最终可以将数组的下一个元素分配给变量x。 我如何使用信号量来同步它?最后一个读取数据的进程B应该向写信号量发出信号,以便A进程写入下一个元素。我怎样才能知道每个B进程何时读取数据?

  • 问题内容: 我需要在与另一个Java应用程序分开的JVM中调用.jar文件,它非常占用CPU,因此应以后台优先级运行,以免影响系统的其余部分。有没有跨平台的方法可以做到这一点? 问题答案: 简单的答案是,没有可移植的方法来更改Java中进程的优先级。(线程-是,进程-否。) 如果您的Java应用程序需要启动一个新的JVM来运行CPU密集型应用程序,那么很可能它不是完全可移植的。例如,通常需要提供j

  • 问题内容: 在我阅读的问题中,我们建议在进程上使用线程,因为线程速度更快。我决定使用程序的线程来编辑Wikipedia中某个类别的文章。该程序获取要编辑的文章列表,然后将文章划分为10个线程。这样一来,我每分钟进行6-7次编辑,这与我没有使用线程的速度相同。当我启动程序的多个实例并为每个实例指定要处理的类别时,我看到每个进程每分钟可以进行6-7次编辑(我用5个进程进行了测试)。 为什么我的流程更快