如何限制我的Windows应用程序只能生成进程的单个实例?
本文关键字:进程 单个 实例 我的 何限制 Windows 应用程序 | 更新日期: 2023-09-27 18:14:10
我正在开发一个Windows应用程序。我使用第三方工具创建了一个帮助文件(.chm),并从Windows应用程序调用它。当我单击 help 菜单项或按F1时,帮助文件被成功调用。
我面临的问题是,如果我再次点击菜单项或按F1(当应用程序打开并且我没有关闭以前的帮助文件时),它会打开帮助文件的另一个实例。
让我通过一个例子来说明:我希望它就像"纸牌"游戏一样。无论你按多少次F1或Contents菜单项,它只显示一个帮助窗口。
我想做和"纸牌"一样的事情。我不希望创建多个实例。
我希望你能理解我的问题。如果我的查询是错误的,请让我知道。我把我的代码贴在下面。 ProcessStartInfo info;
Process exeprocess;
下面的代码是在帮助菜单项单击事件。
private void mnuContents_Click(object sender, EventArgs e)
{
string ApplicationPath=ConfigurationSettings.AppSettings["HelpFile"].ToString();
info = new ProcessStartInfo(ApplicationPath);
//Process.Start(info);
exeprocess = Process.Start(info);
}
一个解决方案是:
-
让你的应用程序创建一个系统范围的资源(下面的例子使用Win32互斥锁)
-
在生成.chm之前检查资源(我想你可能正在使用ShellExec或一些变体来生成帮助文件)
另一种不同的方法是查看当前正在运行的进程是否与将要生成的进程匹配。下面是这种方法的示例代码:
http://www.dotnetperls.com/single-instance-windows-form您有一个Process
对象,因此您可能应该将它存储在某个地方,并在下次调用帮助命令时检查它是否仍然处于活动状态。你可以用Process.HasExited
。如果它已经退出,则通过调用Dispose()
来清理Process
对象,然后启动一个新实例,再次将其存储起来。
好了,下面是启动CHM查看器的代码块:
private void mnuContents_Click(object sender, EventArgs e)
{
string ApplicationPath=ConfigurationSettings.AppSettings["HelpFile"].ToString();
info = new ProcessStartInfo(ApplicationPath);
//Process.Start(info);
exeprocess = Process.Start(info);
}
在exeprocess中有一个名为Id的属性。你需要在下一次用户按F1或菜单键时跟踪该Id。
你需要做一个像
这样的检查 private void mnuContents_Click(object sender, EventArgs e)
{
if (Process.GetProcessById(self.previousId) != null) {
string ApplicationPath=ConfigurationSettings.AppSettings["HelpFile"].ToString();
info = new ProcessStartInfo(ApplicationPath);
//Process.Start(info);
exeprocess = Process.Start(info);
self.previousId = exeprocess.Id;
}
}
这样就可以了。如果您想更花哨一点,还可以将已经运行的进程也放到前台。