我需要一个简单的系统,允许一个进程检查另一个进程是否正在运行(我想我可以使用Process.getProcessByName或类似方法做到这一点)然后在该进程中触发一个假定它的事件。
当我说触发事件时,我并不是字面意思。我只需要在第二个过程中触发一个sub。
我知道像这样的IPC通常会用管道或遥控器或类似的东西完成,但我没有这些经验,我正在寻找快速的解决方案,所以除非这些可以相对容易地使用来解决这个问题,我正在寻找替代方案。
如果不清楚,我会添加细节。
编辑:两个进程都将在同一台计算机上运行。
感谢您的帮助,
萨姆。
答案 0 :(得分:2)
这是使用等待句柄的一种非常简单的方法。如果删除所有取消代码可能会更简单,如果您不需要取消HandleMessage线程,则这不是绝对必要的。
应用程序1(信令应用程序)
public partial class MainWindow : Window
{
readonly EventWaitHandle _waitHandle =
new EventWaitHandle(false, EventResetMode.AutoReset,
"3bee6ac3-2b48-4515-82f5-4fee255a674e");
public MainWindow()
{
InitializeComponent();
}
private void Button_Click_1(object sender, RoutedEventArgs e)
{
_waitHandle.Set();
}
}
申请2(已通知的应用程序)
public partial class MainWindow
{
private readonly EventWaitHandle _waitHandle =
new EventWaitHandle(false, EventResetMode.AutoReset,
"3bee6ac3-2b48-4515-82f5-4fee255a674e"); // a unique name
private readonly CancellationToken _token;
private readonly CancellationTokenSource _tokenSource;
public MainWindow()
{
InitializeComponent();
_tokenSource = new CancellationTokenSource();
_token = _tokenSource.Token;
Task.Factory.StartNew(HandleMessage, _token);
}
private void HandleMessage()
{
while(!_token.IsCancellationRequested)
{
// wait for signal - but only for 1 second
// so we can check for cancellation
if (_waitHandle.WaitOne(1000))
{
Debug.WriteLine("Message received");
}
}
Debug.WriteLine("Cancelled");
}
private void Button_Click_1(object sender, RoutedEventArgs e)
{
// stop receiving
_tokenSource.Cancel();
}
}
答案 1 :(得分:1)
在.NET中,最好的想法是使用WCF。 WCF不仅适用于Web服务,还适用于任何进程之间的通信,无论这些进程是在相同还是不同的机器上。如果您有任何WCF服务经验,这是最快的解决方案。这是一个描述方法的教程:
http://www.switchonthecode.com/tutorials/wcf-tutorial-basic-interprocess-communication
抱歉,我没有写任何一个例子,我正在写这封电话。希望这有帮助!