C产品在市场上有哪些独特优势?
- 内容介绍
- 文章标签
- 相关推荐
本文共计820个文字,预计阅读时间需要4分钟。
在最近做的Winform程序中,若需打开一个已存在的程序,只需激活该程序的窗口,并显示在桌面的最前端。通过Google搜索,找到了许多解决方案。以下我整理了三种方案:
1. 使用FindWindow函数查找窗口句柄,然后使用SetForegroundWindow函数激活窗口。
2.使用EnumWindows函数遍历所有窗口,找到目标窗口后激活。
3.使用GetWindowThreadProcessId函数获取窗口的进程ID,然后使用OpenProcess和SuspendThread函数控制进程,最后使用ResumeThread和CloseHandle函数恢复进程。
最近在做winform的程序中,需要只能打开一个程序,如果已经存在,则激活该程序的窗口,并显示在最前端。在网上google了一哈,找到了很多的解决方案。这里我整理了3种方案,并经过了测试,现和朋友们分享:
一、使用用互斥量(System.Threading.Mutex)
同步基元,它只向一个线程授予对共享资源的独占访问权。在程序启动时候,请求一个互斥体,如果能获取对指定互斥的访问权,就职运行一个实例。
代码 boolcreateNew;using(System.Threading.Mutexmutex=newSystem.Threading.Mutex(true,Application.ProductName,outcreateNew))
{
if(createNew)
{
Application.Run(newForm1());
}
else
{
MessageBox.Show("应用程序已经在运行中...") System.Threading.Thread.Sleep(1000);
System.Environment.Exit(1);
}
}
二、使用进程名
if(processes.Length>1)
{
MessageBox.Show("应用程序已经在运行中。。");
Thread.Sleep(1000);
System.Environment.Exit(1);
}
else
{
Application.Run(newForm1());
}
三、调用Win32 API,并激活并程序的窗口,显示在最前端
代码 ///该函数设置由不同线程产生的窗口的显示状态///</summary>
///<paramname="hWnd">窗口句柄</param>
///<paramname="cmdShow">指定窗口如何显示。查看允许值列表,请查阅ShowWlndow函数的说明部分</param>
///<returns>如果函数原来可见,返回值为非零;如果函数原来被隐藏,返回值为零</returns>
[DllImport("User32.dll")]
privatestaticexternboolShowWindowAsync(IntPtrhWnd,intcmdShow);
///<summary>
///该函数将创建指定窗口的线程设置到前台,并且激活该窗口。键盘输入转向该窗口,并为用户改各种可视的记号。
///系统给创建前台窗口的线程分配的权限稍高于其他线程。
///</summary>
///<paramname="hWnd">将被激活并被调入前台的窗口句柄</param>
///<returns>如果窗口设入了前台,返回值为非零;如果窗口未被设入前台,返回值为零</returns>
[DllImport("User32.dll")]
privatestaticexternboolSetForegroundWindow(IntPtrhWnd); 代码 privateconstintSW_SHOWNOMAL=1;
privatestaticvoidHandleRunningInstance(Processinstance)
{
ShowWindowAsync(instance.MainWindowHandle,SW_SHOWNOMAL);//显示
SetForegroundWindow(instance.MainWindowHandle);//当到最前端
}
privatestaticProcessRuningInstance()
{
ProcesscurrentProcess=Process.GetCurrentProcess();
Process[]Processes=Process.GetProcessesByName(currentProcess.ProcessName);
foreach(ProcessprocessinProcesses)
{
if(process.Id!=currentProcess.Id)
{
if(Assembly.GetExecutingAssembly().Location.Replace("/","\\")==currentProcess.MainModule.FileName)
{
returnprocess;
}
}
}
returnnull;
} 代码 Processprocess=RuningInstance();
if(process==null)
{
Application.Run(newForm1());
}
else
{
MessageBox.Show("应用程序已经在运行中。。。"); HandleRunningInstance(process);
//System.Threading.Thread.Sleep(1000);
//System.Environment.Exit(1);
}
本文共计820个文字,预计阅读时间需要4分钟。
在最近做的Winform程序中,若需打开一个已存在的程序,只需激活该程序的窗口,并显示在桌面的最前端。通过Google搜索,找到了许多解决方案。以下我整理了三种方案:
1. 使用FindWindow函数查找窗口句柄,然后使用SetForegroundWindow函数激活窗口。
2.使用EnumWindows函数遍历所有窗口,找到目标窗口后激活。
3.使用GetWindowThreadProcessId函数获取窗口的进程ID,然后使用OpenProcess和SuspendThread函数控制进程,最后使用ResumeThread和CloseHandle函数恢复进程。
最近在做winform的程序中,需要只能打开一个程序,如果已经存在,则激活该程序的窗口,并显示在最前端。在网上google了一哈,找到了很多的解决方案。这里我整理了3种方案,并经过了测试,现和朋友们分享:
一、使用用互斥量(System.Threading.Mutex)
同步基元,它只向一个线程授予对共享资源的独占访问权。在程序启动时候,请求一个互斥体,如果能获取对指定互斥的访问权,就职运行一个实例。
代码 boolcreateNew;using(System.Threading.Mutexmutex=newSystem.Threading.Mutex(true,Application.ProductName,outcreateNew))
{
if(createNew)
{
Application.Run(newForm1());
}
else
{
MessageBox.Show("应用程序已经在运行中...") System.Threading.Thread.Sleep(1000);
System.Environment.Exit(1);
}
}
二、使用进程名
if(processes.Length>1)
{
MessageBox.Show("应用程序已经在运行中。。");
Thread.Sleep(1000);
System.Environment.Exit(1);
}
else
{
Application.Run(newForm1());
}
三、调用Win32 API,并激活并程序的窗口,显示在最前端
代码 ///该函数设置由不同线程产生的窗口的显示状态///</summary>
///<paramname="hWnd">窗口句柄</param>
///<paramname="cmdShow">指定窗口如何显示。查看允许值列表,请查阅ShowWlndow函数的说明部分</param>
///<returns>如果函数原来可见,返回值为非零;如果函数原来被隐藏,返回值为零</returns>
[DllImport("User32.dll")]
privatestaticexternboolShowWindowAsync(IntPtrhWnd,intcmdShow);
///<summary>
///该函数将创建指定窗口的线程设置到前台,并且激活该窗口。键盘输入转向该窗口,并为用户改各种可视的记号。
///系统给创建前台窗口的线程分配的权限稍高于其他线程。
///</summary>
///<paramname="hWnd">将被激活并被调入前台的窗口句柄</param>
///<returns>如果窗口设入了前台,返回值为非零;如果窗口未被设入前台,返回值为零</returns>
[DllImport("User32.dll")]
privatestaticexternboolSetForegroundWindow(IntPtrhWnd); 代码 privateconstintSW_SHOWNOMAL=1;
privatestaticvoidHandleRunningInstance(Processinstance)
{
ShowWindowAsync(instance.MainWindowHandle,SW_SHOWNOMAL);//显示
SetForegroundWindow(instance.MainWindowHandle);//当到最前端
}
privatestaticProcessRuningInstance()
{
ProcesscurrentProcess=Process.GetCurrentProcess();
Process[]Processes=Process.GetProcessesByName(currentProcess.ProcessName);
foreach(ProcessprocessinProcesses)
{
if(process.Id!=currentProcess.Id)
{
if(Assembly.GetExecutingAssembly().Location.Replace("/","\\")==currentProcess.MainModule.FileName)
{
returnprocess;
}
}
}
returnnull;
} 代码 Processprocess=RuningInstance();
if(process==null)
{
Application.Run(newForm1());
}
else
{
MessageBox.Show("应用程序已经在运行中。。。"); HandleRunningInstance(process);
//System.Threading.Thread.Sleep(1000);
//System.Environment.Exit(1);
}

