C#C#程序只同意运行一个实例的化解方案

    
近日在做winform的顺序中,须求只可以打开一个程序,若是已经存在,则激活该程序的窗口,并出示在最前端。在网上google了一哈,找到了很多的化解方案。那里我整理了3种方案,并通过了测试,现和爱侣们享受:

一、使用用互斥量(System.Threading.Mutex)

 同步基元,它只向一个线程授予对共享资源的独占访问权。在程序启动时候,请求一个互斥体,即便能获取对点名互斥的访问权,就职运行一个实例。

C# 1C# 2代码

 bool createNew;
            using (System.Threading.Mutex mutex = new System.Threading.Mutex(true, Application.ProductName, out createNew))
            {
                if (createNew)
                {
                    Application.Run(new Form1());
                }
                else
                {
                    MessageBox.Show(“应用程序已经在运行中…”)

                    System.Threading.Thread.Sleep(1000);
                    System.Environment.Exit(1);
                }
            }

 

 

二、使用进度名

 

C# 3C# 4代码

   Process[] processes = System.Diagnostics.Process.GetProcessesByName(Application.CompanyName);
            if (processes.Length > 1)
            {
                MessageBox.Show(“应用程序已经在运作中。。”);
                Thread.Sleep(1000);
                System.Environment.Exit(1);
            }
            else
            {
                Application.Run(new Form1());
            }

 

 

三、调用Win32 API,并激活并先后的窗口,展现在最前端

 

C# 5C# 6代码

  /// 该函数设置由不同线程暴发的窗口的显得状态
        /// </summary>
        /// <param name=”hWnd”>窗口句柄</param>
        /// <param name=”cmdShow”>指定窗口怎么着体现。查看允许值列表,请查阅ShowWlndow函数的印证有些</param>
        /// <returns>即使函数原来可知,再次回到值为非零;假如函数原来被埋伏,重回值为零</returns>
        [DllImport(“User32.dll”)]
        private static extern bool ShowWindowAsync(IntPtr hWnd, int cmdShow);
        /// <summary>
        ///  该函数将开创指定窗口的线程设置到前台,并且激活该窗口。键盘输入转向该窗口,并为用户改各类可视的号子。
        ///  系统给创制前台窗口的线程分配的权力稍高于其他线程。 
        /// </summary>
        /// <param name=”hWnd”>将被激活并被调入前台的窗口句柄</param>
        /// <returns>假如窗口设入了前台,再次回到值为非零;假设窗口未被设入前台,重临值为零</returns>
        [DllImport(“User32.dll”)]
        private static extern bool SetForegroundWindow(IntPtr hWnd);

 

 

C# 7C# 8代码

  private const int SW_SHOWNOMAL = 1;
        private static void HandleRunningInstance(Process instance)
        {
            ShowWindowAsync(instance.MainWindowHandle, SW_SHOWNOMAL);//显示
            SetForegroundWindow(instance.MainWindowHandle);//当到最前端
        }
        private static Process RuningInstance()
        {
            Process currentProcess = Process.GetCurrentProcess();
            Process[] Processes = Process.GetProcessesByName(currentProcess.ProcessName);
            foreach (Process process in Processes)
            {
                if (process.Id != currentProcess.Id)
                {
                    if (Assembly.GetExecutingAssembly().Location.Replace(“/”, “\\”) == currentProcess.MainModule.FileName)
                    {
                        return process;
                    }
                }
            }
            return null;
        }

 

C# 9C# 10代码

  Process process = RuningInstance();
            if (process == null)
            {
                Application.Run(new Form1());
            }
            else
            {
                MessageBox.Show(“应用程序已经在运作中。。。”);

               
HandleRunningInstance(process);
                //System.Threading.Thread.Sleep(1000);
                //System.Environment.Exit(1);
            }

 

此间整理了三种方案,希望恋人们提出更加多的化解方案。谢谢!

Best Regards,

Charles Chen

相关文章