Проверьте, запущен ли конкретный exe-файл

Я хочу знать, как я могу проверить программу в определенном месте, если она запущена. Например, есть два места для тестирования.exe в c:loc1test - ... exe и c:loc2test - ... исполняемый. Я только хотел узнать, c:loc1test - ... exe работает и не все экземпляры теста.исполняемый.

8 ответов


bool isRunning = Process.GetProcessesByName("test")
                .FirstOrDefault(p => p.MainModule.FileName.StartsWith(@"c:\loc1")) != default(Process);

Это моя улучшенная функция :

private bool ProgramIsRunning(string FullPath)
{
    string FilePath =  Path.GetDirectoryName(FullPath);
    string FileName = Path.GetFileNameWithoutExtension(FullPath).ToLower();
    bool isRunning = false;

    Process[] pList = Process.GetProcessesByName(FileName);

    foreach (Process p in pList) {
        if (p.MainModule.FileName.StartsWith(FilePath, StringComparison.InvariantCultureIgnoreCase))
        {
            isRunning = true;
            break;
        }
    }

    return isRunning;
}

и использовать его как :

ProgramIsRunning(@"c:\loc1\test.exe");

попробуйте это... Я использую его, чтобы определить при запуске, если другой процесс уже запущен с тем же именем, что и exe, который я пытаюсь запустить, а затем просто вывести его на передний план (и сосредоточиться), если он уже запущен... Вы можете изменить его, чтобы взять имя процесса и проверить для этого конкретного имени... Это покажет вам, есть ли процесс с определенным именем, но не где этот процесс был загружен ...

Если есть процесс, работающий с указанным имя, тогда, если этот процесс имел открытый доступный метод, который возвращает, откуда он был загружен, вы можете вызвать этот метод в запущенном процессе, иначе, я не знаю..

но просто из любопытства, почему вас это волнует, если они не разные? И если они отличаются каким-то образом, код для использования этой разницы (что бы это ни было), чтобы обнаружить, что загружено. Но если они одинаковы, как может иметь значение, какой образ на диске использовался для его загрузки?

    [DllImport("user32.dll")]
    private static extern bool SetForegroundWindow(IntPtr hWnd);
    [DllImport("user32.dll")]
    private static extern bool ShowWindowAsync(IntPtr hWnd, int nCmdShow);
    [DllImport("user32.dll")]
    private static extern bool IsIconic(IntPtr hWnd);

    private const int SW_HIDE = 0;
    private const int SW_SHOWNORMAL = 1;
    private const int SW_SHOWMINIMIZED = 2;
    private const int SW_SHOWMAXIMIZED = 3;
    private const int SW_SHOWNOACTIVATE = 4;
    private const int SW_RESTORE = 9;
    private const int SW_SHOWDEFAULT = 10;

 private static bool IsAlreadyRunning()
    {
        // get all processes by Current Process name
        Process[] processes = 
            Process.GetProcessesByName(
                Process.GetCurrentProcess().ProcessName);

        // if there is more than one process...
        if (processes.Length > 1) 
        {
            // if other process id is OUR process ID...
            // then the other process is at index 1
            // otherwise other process is at index 0
            int n = (processes[0].Id == Process.GetCurrentProcess().Id) ? 1 : 0;

            // get the window handle
            IntPtr hWnd = processes[n].MainWindowHandle;

            // if iconic, we need to restore the window
            if (IsIconic(hWnd)) ShowWindowAsync(hWnd, SW_RESTORE);

            // Bring it to the foreground
            SetForegroundWindow(hWnd);
            return true;
        }
        return false;
    }

вы должны перебрать все существующие процессы, а затем проверить их свойство MainModule для имени файла, который вы ищете. Что-то вроде этого!--2-->

using System.Diagnostics;
using System.IO;

//...

string fileNameToFilter = Path.GetFullPath("c:\loc1\test.exe");

foreach (Process p in Process.GetProcesses())
{
   string fileName = Path.GetFullPath(p.MainModule.FileName);

   //cehck for equality (case insensitive)
   if (string.Compare(fileNameToFilter, fileName, true) == 0)
   {
      //matching...
   }
}

эта функция может помочь:

using System.Diagnostics;

public bool IsProcessOpen(string name)
{
    foreach (Process clsProcess in Process.GetProcesses()) {
        if (clsProcess.ProcessName.Contains(name))
        {
            return true;
        }
    }
    return false;
} 

источник:http://www.dreamincode.net/code/snippet1541.htm


вы могли бы использовать именованный мьютекс, вот им от структуры каталога приложения.


что-то вроде этого. GetMainModuleFileName помогает открыть процесс x64 от x86.

  [DllImport("kernel32.dll")]
  public static extern bool QueryFullProcessImageName(IntPtr hprocess, int dwFlags, StringBuilder lpExeName, out int size);

  private bool CheckRunningProcess(string processName, string path) {

  Process[] processes = Process.GetProcessesByName(processName);
  foreach(Process p in processes) {
    var name = GetMainModuleFileName(p);
    if (name == null)
      continue;
    if (string.Equals(name, path, StringComparison.InvariantCultureIgnoreCase)) {
      return true;
    }
  }
  return false;
}

// Get x64 process module name from x86 process
private static string GetMainModuleFileName(Process process, int buffer = 1024) {

  var fileNameBuilder = new StringBuilder(buffer);
  int bufferLength = fileNameBuilder.Capacity + 1;
  return QueryFullProcessImageName(process.Handle, 0, fileNameBuilder, out bufferLength) ?
      fileNameBuilder.ToString() :
      null;
}

System.Reflection.Assembly.GetEntryAssembly()

это принесет вам много информации о сборке ввода, например:

System.Reflection.Assembly.GetEntryAssembly().CodeBase;

Это покажет местоположение работающей сборки.