Проверьте, запущен ли конкретный 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;
}
вы могли бы использовать именованный мьютекс, вот им от структуры каталога приложения.
что-то вроде этого. 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;
Это покажет местоположение работающей сборки.