windows 用 tasklist 命令,linux 用 ps 命令。
c 使用 popen 函数来解析返回的字符串,一旦发现 xx 进程运行则用 system 函数启动另一个程序。
如果需要持续检测,用 while 加 sleep 轮询。
C# WinForm判断程序是否已经运行,使程序只能运行一个实例有很多方法。第一种,通过进程判断是否启动:
[csharp] view plain copy
static class Program
{
/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()
{
//获取当前进程的ID
int pId = Process.GetCurrentProcess().Id
bool isRun = false
foreach (Process p in Process.GetProcessesByName("CallMaster"))
{
//取得当前程序的进程,进行比较
if (Common.GetPath().ToLower() == p.MainModule.FileName.
#include<windows.h>#include <stdio.h>
#include "PSAPI.H"
#pragma comment( lib, "PSAPI.LIB" )
BOOL EnablePrivilege(HANDLE hToken,LPCSTR szPrivName)
int main(void)
{
DWORD processid[1024],needed,processcount,i
HANDLE hProcess
HMODULE hModule
char path[MAX_PATH] = "",temp[256]
HANDLE hToken
printf("ShowProcessPath 2.0 with [Process Status API]\n\n")
if ( OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES,&hToken) )
{
if (EnablePrivilege(hToken,SE_DEBUG_NAME))
{
EnumProcesses(processid, sizeof(processid), &needed)
processcount=needed/sizeof(DWORD)
for (i=0i<processcounti++)
{
hProcess=OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ,false,processid[i])
if (hProcess)
{
EnumProcessModules(hProcess, &hModule, sizeof(hModule), &needed)
GetModuleFileNameEx(hProcess, hModule, path, sizeof(path))
>>>>在这里判断是否是你所需要的文件
GetShortPathName(path,path,256)
itoa(processid[i],temp,10)
printf("%s --- %s\n",path,temp)
}
else
printf("Failed!!!\n")
}
}
}
CloseHandle(hProcess)
CloseHandle(hModule)
itoa(processcount,temp,10)
printf("\nProcess Count:%s\n\n",temp)
return 0
}
BOOL EnablePrivilege(HANDLE hToken,LPCSTR szPrivName)
{
TOKEN_PRIVILEGES tkp
LookupPrivilegeValue( NULL,szPrivName,&tkp.Privileges[0].Luid )//修改进程权限
tkp.PrivilegeCount=1
tkp.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED
AdjustTokenPrivileges( hToken,FALSE,&tkp,sizeof tkp,NULL,NULL )//通知系统修改进程权限
return( (GetLastError()==ERROR_SUCCESS) )
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)