判断指定的进程或程序是否存在方法小结(vc等)

所属分类: 软件编程 / C 语言 阅读数: 144
收藏 0 赞 0 分享
一、判断指定程序名的进程是否存在
     BOOL EnumWindows( WNDENUMPROC lpEnumFunc, // pointer to callback function LPARAM lParam //   application-defined value);
       The EnumWindows function enumerates all top-level windows on the screen by passing the handle to each window, in turn, to an application-defined callback function. EnumWindows continues until the last top-level window is enumerated or the callback function returns FALSE.
复制代码 代码如下:

BOOL CALLBACK IpEnumFunc(HWND hwnd,LPARAM lParam)
{
 char wndName[100];
 ::GetWindowText(hwnd,wndName,sizeof(wndName));
 if(wndName!="")
 {
  if(strcmp(wndName,name1)==0)
  {
   WndHnd=hwnd;
   flag=1;
  }
  }
 return 1;
}

二、判断指定进程名的进程是否存在
复制代码 代码如下:

DWORD GetProcessidFromName(LPCTSTR name)
{
 PROCESSENTRY32 pe;
 DWORD id=0;
 HANDLE hSnapshot=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
 pe.dwSize=sizeof(PROCESSENTRY32);
 if(!Process32First(hSnapshot,&pe))
  return 0;
 while(1)
 {
  pe.dwSize=sizeof(PROCESSENTRY32);
  if(Process32Next(hSnapshot,&pe)==FALSE)
   break;
  if(strcmp(pe.szExeFile,name)==0)
  {
   id=pe.th32ProcessID;
   break;
  }
 }
 CloseHandle(hSnapshot);
 return id;
}

如果返回值不为零,则存在,否则不存在。
三、VC判断程序调用的外部进程是否结束
复制代码 代码如下:

PROCESS_INFORMATION pi;
    STARTUPINFO si;
    memset(&si,0,sizeof(si));
    si.cb=sizeof(si);
    si.wShowWindow=SW_HIDE;
    si.dwFlags=STARTF_USESHOWWINDOW;
bool fRet=CreateProcess(NULL,str.GetBuffer(str.GetLength()),NULL,FALSE,NULL,NORMAL_PRIORITY_CLASS   |   CREATE_NO_WINDOW,NULL,NULL,&si,&pi);
///判断
DWORD   ExitCode;  
ExitCode=STILL_ACTIVE;
while(ExitCode==STILL_ACTIVE)
{
   GetExitCodeProcess(pi.hProcess,&ExitCode);
}

四、VC判断进程是否存在?比如我想知道记事本是否运行,要用到哪些函数?
复制代码 代码如下:

enProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ,  FALSE,aProcesses[i]);    
  //   取得特定PID的进程名    
  if   (hProcess )    
  {    
  if   ( EnumProcessModules(hProcess,&hMod,sizeof(hMod), &cbNeeded))    
  {    
  GetModuleBaseName( hProcess, hMod,szProcessName,sizeof(szProcessName));    
  //将取得的进程名与输入的进程名比较,如相同则返回进程PID    
  if(!stricmp(szProcessName, InputProcessName))    
  {    
  CloseHandle(hProcess);    
  return   aProcesses[i];    
  }    
  }    
  }//end   of   if   (hProcess)    
  }//end   of   for    
  //没有找到相应的进程名,返回0    
  CloseHandle(hProcess);    
  return   0;    
  }  

也可以枚举得到所有进程的应用程序名,然后和知道应用程序名比较判断。
五、实现程序只运行一次的方法
        实现程序只运行一次的方法很多,但是原理都是一样的,就是运行第一次的时候设置一个标记,每次运行的时候检查该标记,如果有就说明已经运行了。
具体实现:
1、在程序初始化的时候   (InitInstance())   枚举所有的窗口,查找本程序的实例是否存在  
2、在主窗口初始化的时候在本窗口的属性列表中添加一个标记,以便程序查找.
部分关键代码 :
1、在App的InitInstance()中枚举所有窗口,查找本程序实例
复制代码 代码如下:

HWND   oldHWnd   =   NULL;
EnumWindows(EnumWndProc,(LPARAM)&oldHWnd);  //枚举所有运行的窗口
if(oldHWnd   !=   NULL)
{
AfxMessageBox( "本程序已经在运行了 ");
::ShowWindow(oldHWnd,SW_SHOWNORMAL);   //激活找到的前一个程序
::SetForegroundWindow(oldHWnd);       //把它设为前景窗口
return   false;                       //退出本次运行
}

2、添加EnumWndProc窗口过程函数://添加的标识只运行一次的属性名
复制代码 代码如下:

CString   g_szPropName  =  "Your Prop Name ";       //自己定义一个属性名
HANDLE    g_hValue  =  (HANDLE)1;                   //自己定义一个属性值
BOOL   CALLBACK   EnumWndProc(HWND   hwnd,LPARAM   lParam)
{
HANDLE   h   =   GetProp(hwnd,g_szPropName);
if(   h   ==   g_hValue)
{
*(HWND*)lParam   =   hwnd;
return   false;
}
return   true;
}

3、在主窗口的   OnInitDialog()中添加属性   //设置窗口属性
SetProp(m_hWnd,g_szPropName,g_hValue);
再次启动时,先检查当前存在的所有窗口,如果有标题相同的,则把先前运行的窗口当成当前窗口
我的程序如下:
复制代码 代码如下:

HWND   hWnd_Exist;
hWnd_Exist=::GetDesktopWindow();
hWnd_Exist=::GetWindow(hWnd_Exist,GW_CHILD);
for(;;)
{
if(hWnd_Exist==NULL)
{
break;
}
char   s[256];
memset(s,0,256);
::SendMessage(hWnd_Exist,WM_GETTEXT,255,(LONG)s);
if(strstr(s, "****** ")!=NULL)
break;
hWnd_Exist=::GetWindow(hWnd_Exist,GW_HWNDNEXT);
}
if(hWnd_Exist   !=   NULL)
{
::ShowWindow(hWnd_Exist,SW_SHOWNORMAL);
::SetForegroundWindow(hWnd_Exist);
exit(0);
}

声明一个全局   CMutex   变量:
--------------------------------------------------------------------------------
CMutex   mutexApp(FALSE,   _T( "VPOS2000Server "));   //用此互斥量阻止多个实例
在你的   CWinApp   类的重载函数:   InitInstance   中加入如下代码: 
复制代码 代码如下:

if   (!mutexApp.Lock(1))
return   FALSE;
::CreateMutex(NULL, TRUE, m_pszExeName);  
        if(ERROR_ALREADY_EXISTS == GetLastError())  
        {  
                CWnd* pPrevHwnd =  CWnd::GetDesktopWindow()-> GetWindow(GW_CHILD);  
                while(pPrevHwnd)  
                {  
                     if(::GetProp(pPrevHwnd-> GetSafeHwnd(), m_pszExeName))  
                      {  
                          if(pPrevHwnd-> IsIconic())  
                           {  
                             pPrevHwnd-> ShowWindow(SW_RESTORE);  
                           }  
                           pPrevHwnd-> SetForegroundWindow();  
                           pPrevHwnd-> GetLastActivePopup()-> SetForegroundWindow();  
                           return   FALSE;  
                        }  
                        pPrevHwnd   =   pPrevHwnd-> GetWindow(GW_HWNDNEXT);  
                }  
                TRACE( "Could  not  fond  frevious instance main window ! ");  
                return   FALSE;  
        }

创建一个全局的互斥量,每次启动时检查是否存在。
复制代码 代码如下:

BOOL   CRTDBApp::OnlyOneInstance()
{
if(::CreateMutex(NULL, TRUE, "onlyone ") == NULL ) 
 {
TRACE0( "CreateMutex   error. ");
return   FALSE;
};
if( ::GetLastError()   == ERROR_ALREADY_EXISTS)   {
CWnd*   pPrevWnd   =   CWnd::FindWindow(NULL, "onlyonehwnd ");
if(pPrevWnd)
{
if(   pPrevWnd-> IsIconic())
pPrevWnd-> ShowWindow(SW_RESTORE);
pPrevWnd-> SetForegroundWindow();
pPrevWnd-> GetLastActivePopup()-> SetForegroundWindow();
return   FALSE; 
}
};
return   TRUE;
}
更多精彩内容其他人还在看

用标准c++实现string与各种类型之间的转换

这个类在头文件中定义, < sstream>库定义了三种类:istringstream、ostringstream和stringstream,分别用来进行流的输入、输出和输入输出操作。另外,每个类都有一个对应的宽字符集版本
收藏 0 赞 0 分享

C++如何通过ostringstream实现任意类型转string

再使用整型转string的时候感觉有点棘手,因为itoa不是标准C里面的,而且即便是有itoa,其他类型转string不是很方便。后来去网上找了一下,发现有一个好方法
收藏 0 赞 0 分享

C/C++指针小结

要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区
收藏 0 赞 0 分享

C++ 类的静态成员深入解析

在C++中类的静态成员变量和静态成员函数是个容易出错的地方,本文先通过几个例子来总结静态成员变量和成员函数使用规则,再给出一个实例来加深印象
收藏 0 赞 0 分享

C++类的静态成员初始化详细讲解

通常静态数据成员在类声明中声明,在包含类方法的文件中初始化.初始化时使用作用域操作符来指出静态成员所属的类.但如果静态成员是整型或是枚举型const,则可以在类声明中初始化
收藏 0 赞 0 分享

C++类静态成员与类静态成员函数详解

静态成员不可在类体内进行赋值,因为它是被所有该类的对象所共享的。你在一个对象里给它赋值,其他对象里的该成员也会发生变化。为了避免混乱,所以不可在类体内进行赋值
收藏 0 赞 0 分享

C++中的friend友元函数详细解析

友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类。友元函数的特点是能够访问类中的私有成员的非成员函数。友元函数从语法上看,它与普通函数一样,即在定义上和调用上与普通函数一样
收藏 0 赞 0 分享

static全局变量与普通的全局变量的区别详细解析

以下是对static全局变量与普通的全局变量的区别进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
收藏 0 赞 0 分享

C++ explicit关键字的应用方法详细讲解

C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有"显式"那么必然就有"隐式",那么什么是显示而什么又是隐式的呢?下面就让我们一起来看看这方面的知识吧
收藏 0 赞 0 分享

教你5分钟轻松搞定内存字节对齐

随便google一下,人家就可以跟你解释的,一大堆的道理,我们没怎么多时间,讨论为何要对齐.直入主题,怎么判断内存对齐规则,sizeof的结果怎么来的,请牢记以下3条原则
收藏 0 赞 0 分享
查看更多