打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
C#判断程序是否运行的方法
C#判断程序是否运行的方法
2009-12-08 09:28

命名空间是using System.Diagnostics;

string name = "aaa";//程序进程名称
   int ProgressCount = 0123456;//判断进程是否运行的标识
   Process[] prc = Process.GetProcesses();
   foreach(Process pr in prc) //遍历整个进程
   {
            if (name == pr.ProcessName) //如果进程存在
            {    
                    ProgressCount = 0; //计数器清空
                     return;
            }
   }
   if(ProgressCount!=0)//如果计数器不为0,说名所指定程序没有运行
   {
    try
    {
     //调用外部程序
     Process MyProcess = new Process();
     MyProcess.StartInfo.FileName = "d:/aaa.exe";
     MyProcess.StartInfo.Verb = "Open";
     MyProcess.StartInfo.CreateNoWindow = true;
     MyProcess.Start();
    }
    catch(Exception d)
    {
     MessageBox.Show(d.Message+"","提示!!!!");
    }
   }
   else
   {
    MessageBox.Show("对不起,本地已经有系统正在运行!\n.","提示",MessageBoxButtons.OK,MessageBoxIcon.Warning);
   }

 

From: http://blog.csdn.net/hank212/archive/2007/09/07/1776261.aspx

 

另:

利用Mutex实现只运行一个程序实例
static void Main()
        {
            bool canCreateNew;
           
            //限制单例运行
            Mutex m = new Mutex(true, "AnyName", out canCreateNew);
            if (canCreateNew)
            {
                string filePath = AppDomain.CurrentDomain.BaseDirectory +
                System.Diagnostics.Process.GetCurrentProcess().ProcessName + ".xml";
                if (System.IO.File.Exists(filePath))
                {
                    Application.EnableVisualStyles();
                    Application.SetCompatibleTextRenderingDefault(false);
                    Command.config = new Configurations(filePath);
                    Application.Run(new FormMain());
                }
                else
                {
                    FileHelper.WriteLog(FileHelper.LogType.LTError, "XML not exist");
                }
                m.ReleaseMutex();    //必须
            }
            else
            {
                MessageBox.Show("");
            }
        }

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/gaoyunpeng/archive/2008/05/16/2452052.aspx

 

很多的软件都支持一次只能运行一个程序,比如迅雷。一直搞不清楚这个是怎么做的。最近正好做了一个小工具,需要一个用户在一个网域内只能开启一个这个小工具。这个工具就要支持,在同一个网域内,同一个用户只能开启一个这个工具。
我的做法是:抓取所有正在运行的这个工具的进程,然后和当前网域当前用户的进程比较,如果存在就返回已经运行的当前网域当前用户的进程,不存在就开启。

刚开是我用到了Process.StartInfo.UserName和Process.StartInfo.Domain来抓取进程的用户名和网域,发现抓出来的全是空字串。没办法只有另寻他路。这里用到了WMI , 关于WMI是什么请参阅MSDN.

还是以实际例子来说明吧。首先建一个WINForm的工程,名字就叫做WINFormTest吧。呵呵呵,命名不规范了。

具体代码如下:

static class Program
    {
       
        [DllImport("user32.dll", CharSet = CharSet.Auto)]
        public static extern bool BringWindowToTop(IntPtr hwnd);
        [DllImport("User32.dll")]
        private static extern bool ShowWindowAsync(IntPtr hWnd, int cmdShow);
        [DllImport("User32.dll")]
        private static extern bool SetForegroundWindow(IntPtr hWnd);

        private const int WS_SHOWNORMAL = 1; //0不可见但仍然运行,1居中,2最小化,3最大化
  
     
        /// <summary>
        /// 應用程式的主要進入點。
        /// </summary>
        [STAThread]
        static void Main()
        {
            string szRepeatRun = "";

            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);

           Process instance = RunningInstance();//判断是否已经有运行的程序,如果有就返回该进程,没有返回Null

            if (instance == null)
            {
                Application.Run(new frmWINFormTest());
            }
            else
            {                 

               if (instance.MainWindowHandle.ToString() =="0")
                        MessageBox.Show("该程序已经运行!");               

                // 将窗口提到桌面的最上层,这里如果窗口自小化了,就不能提到最上层,原因正在解决。
                SetForegroundWindow(instance.MainWindowHandle);
              }
           
            //Application.Run(new EIPNotify());
        }
        public static Process RunningInstance()
        {
            int i, j;
            string szUserName, szProcessName, szDomain;//当前进程的用户名,进程名,和网域
            ArrayList ALProcess = new ArrayList();// 存储所有开启的程序的进程ID,用户名,网域
            tagProcess tProcess = new tagProcess();
            j = 0;
            szUserName = szDomain = "";
           
            szProcessName = "";
            Process current = Process.GetCurrentProcess();//得到当前进程
            Process[] processes = Process.GetProcessesByName(current.ProcessName);//得到和当前进程同名的进程
            // WMI 得到任务管理器中的所有的进程。    
            ManagementObjectSearcher psch=new ManagementObjectSearcher("select * from Win32_Process");
           
            foreach(ManagementObject mob in psch.Get())  
            {
                i = mob["Name"].ToString().LastIndexOf('.');
                if (i>=0)
                    szProcessName = mob["Name"].ToString().Substring(0, i);

                // 和当前进程同名,并且不是当前进程存入到Arraylist中

               if (szProcessName == current.ProcessName && mob["processID"].ToString() != current.Id.ToString())
                {
                    string[] pob = new string[2];
                    mob.InvokeMethod("GetOwner", (object[])pob);// 得到进程的相关信息,存储在Object 数组中,其中第一个为用户名,第二个为网域,其它的是什么有待继续研究。
                    object UserName = pob[0];//进程的用户名
                    tProcess.szOldUserName = UserName.ToString();
                    object Domain = pob[1];//进程的网域
                    tProcess.szOldDomain = Domain.ToString();
                    tProcess.szProcessID = mob["processID"].ToString();// 进程的ID
                    ALProcess.Add(tProcess);
                }

                if (szProcessName == current.ProcessName && mob["processID"].ToString() == current.Id.ToString())// 获取当前进程的用户名和网域
                {
                    string[] pob = new string[2];
                    mob.InvokeMethod("GetOwner", (object[])pob);
                    object UserName = pob[0];
                    szUserName = UserName.ToString();
                    object Domain = pob[1];
                    szDomain = Domain.ToString();
                }               
            }
            for (j = 0; j < ALProcess.Count; j++)
            {
                tProcess = (tagProcess)ALProcess[j];
                if (tProcess.szOldUserName == szUserName && tProcess.szOldDomain == szDomain)
                {
                    foreach (Process process in processes)
                    {
                        if ((process.ProcessName == current.ProcessName) && (process.Id != current.Id) && (process.Id.ToString() == tProcess.szProcessID))
                        {
                            return process;
                        }
                    }
                }
            }
            return null;
           
        }
        public struct tagProcess
        {
            public string szProcessID;
            public string szOldUserName;
            public string szOldDomain;
        }

}

另外一种防止重复运行的方法

bool mutex IsNew;
using (System.Threading.Mutex m= new System.Threading.Mutex(true,appName,out IsNew))
{
      if(IsNew)
            //第一次运行,启动程序
       else
            //程序已经在运行,退出

}


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
关于 Android 应用多进程的整理
进程名称相同,根据标题不同而杀掉进程
获取进程列表、名称、路径
如何杀死Word,Excel等进程?
Android核心分析(21)----Android应用框架之AndroidApplication
Android应用程序在新的进程中启动新的Activity的方法和过程分析
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服