• 保证程序只有一个实例运行并且先将旧实例关闭再运行新实例


    using System;
    using System.Collections.Generic;
    using System.Windows.Forms;
    using System.Threading;
    using System.Diagnostics;
    using System.Reflection;

    namespace MyClient
    {
        
        
    static class Program
        {

            
    /// <summary>
            
    /// The main entry point for the application.
            
    /// </summary>
            [STAThread]
            
    static void Main(string[] args)
            {

                Application.EnableVisualStyles();
                Application.SetCompatibleTextRenderingDefault(
    false);
                
    //bool blnCreate;//Another method to make sure only one instance
                
    //Mutex m = new Mutex(true, "MyClient", out blnCreate);
                
    //if (blnCreate)
                CloseRunningInstance();
                Application.Run(
    new MainFrm());
            }
            
    //Close the existed instance of my application
            static void CloseRunningInstance()
            {
                Process current 
    = Process.GetCurrentProcess();
                Process[] processes 
    = Process.GetProcessesByName(current.ProcessName);
                
    //Loop through the running processes in with the same name    
                foreach (Process process in processes)
                {
                    
    //Ignore the current process    
                    if (process.Id != current.Id)
                    {
                        
    //Make sure that the process is running from the exe file.    
                        if (Assembly.GetExecutingAssembly().Location.Replace("/""\\"== current.MainModule.FileName)
                        {
                            
    //Close the other process instance.   
                            process.Kill();
                            process.WaitForExit();
                        }
                    }
                }
            } 
        }
    }
  • 相关阅读:
    向量场中的积分
    Oracle 动态视图4 V$SESSION_WAIT & V$SESSION_EVENT
    Oracle 动态视图3 V$SESSION
    Oracle 动态视图2 V$LOCKED_OBJECT
    Oracle 摘去数据块的面纱
    Oracle 动态视图1 V$LOCK
    Oracle Lock 概述
    Oracle 监听动态注册与静态注册
    Oracle用户进程跟踪
    Oracle SGA参数调整
  • 原文地址:https://www.cnblogs.com/coderzh/p/989375.html
Copyright © 2020-2023  润新知