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

一、判断指定程序名的进程是否存在
     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;
}

(0)

相关推荐

  • VC++开发中完美解决头文件相互包含问题的方法解析

    所谓超前引用是指一个类型在定义之前就被用来定义变量和声明函数. 一般情况下,C/C++要求所有的类型必须在使用前被定义,但是在一些特殊情况下,这种要求无法满足,例如,在类CMyView中保留了一个非模式对话框对象指针,该对象用于显示/修改一些信息.为了实现对话框"应用"按钮,把对话框做的修改立刻更新到view界面上,为此,需要在对话框类中需要保存view类的指针,这样定义关系就变成如下的代码: 复制代码 代码如下: #ifndef __MYVIEW_H__   #define __MY

  • VC++在TXT文件指定位置追加内容的方法

    本文实例讲述了VC++操作文本文件的方法,实现在txt文件指定位置插入内容.对于VC++爱好者有一定的学习参考价值. 主要功能代码如下: void CGoToFileDlg::OnPaint() { if (IsIconic()) { CPaintDC dc(this); SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0); int cxIcon = GetSystemMetrics(SM_CXICON); int cyIcon

  • VC++ 使用 _access函数判断文件或文件夹是否存在

    _access函数 int _access( const char *path, int mode ); int _waccess( const wchar_t *path, int mode ); 参数 path 文件或目录路径. mode 读/写特性. 返回值   如果文件包含特定模式,每个函数返回 0. 函数返回 - 1,则名称文件不存在或不具有特定模式:在这种情况下,如下表errno 所示设置. EACCES 访问被拒绝:文件权限的设置不允许指定的访问权限. ENOENT 未找到文件名或

  • VC++实现CStdioFile写入及读取文件并自动换行的方法

    本文所述CStdioFile可实现在VC++中主要用来写入及读出文件的功能,继承自CFile类,它会自动处理 "\r\n",遇到"\n"自动添加\r并设置光标在当前行,它同时可以自动换行,不过使用CStdioFile在处理大文件时速度有些慢, 用CStdioFile写入读取文件实现代码如下: LPTSTR filter=_T("Playlist Files(.txt)|*.txt|"); CString tempPath; CFileDialog

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

    一.判断指定程序名的进程是否存在     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

  • C#判断指定分区是否是ntfs格式的方法

    本文实例讲述了C#判断指定分区是否是ntfs格式的方法.分享给大家供大家参考.具体如下: using System; using System.IO; namespace RobvanderWoude { class IsNTFS { public static int Main( string[] args ) { try { if ( args.Length == 0 ) { return WriteError( string.Empty ); } if ( args.Length > 1

  • python对指定字符串逆序的6种方法(小结)

    对于一个给定的字符串,逆序输出,这个任务对于python来说是一种很简单的操作,毕竟强大的列表和字符串处理的一些列函数足以应付这些问题 了,今天总结了一下python中对于字符串的逆序输出的几种常用的方法 方法一:直接使用字符串切片功能逆转字符串 #!usr/bin/env python # encoding:utf-8 def strReverse(strDemo): return strDemo[::-1] print(strReverse('pythontab.com')) 结果: moc

  • jQuery判断指定id的对象是否存在的方法

    jQuery判断指定id的对象是否存在,只需要判断对象的length是否大于0即可. 示例: 正确的判断写法如下: if($("#object_id").length>0) { alert('对象存在'); } else { alert('对象不存在'); } 或者直接使用原生的 Javascript 代码来判断: if(document.getElementById("id")) { alert('对象存在'); } else { alert('对象不存在'

  • 利用JS判断字符串是否含有数字与特殊字符的方法小结

    前言 本文主要介绍的是利用JS判断字符串是否含有数字与特殊字符的方法,文中有几种不同的方法,包括普通的JS验证法.正则表达式法,另外还有判断是否为浮点数的js函数,在最后还将简要介绍下isNAN函数的使用方法和例子,来一起学习学习吧. 一.正则表达式方法判断是否为数字,包括判断正整数: function checkRate(input) { var re = /^[0-9]+.?[0-9]*$/; //判断字符串是否为数字,//若判断正整数,则后边是:/^[1-9]+[0-9]*]*$/ if

  • C#实现按照指定长度在数字前补0方法小结

    本文实例总结了C#实现按照指定长度在数字前补0方法.分享给大家供大家参考.具体分析如下: 这里分析了C#按照指定的长度在数字前补0的两种方法 例如123可以转换成000123 String snum = "123"; //方法1 String pnum = snum.PadLeft(6,'0'); //方法2 String fnum = String.Format("{0:000000}",int.Parse(snum)); 希望本文所述对大家的C#程序设计有所帮助

  • JS判断数组里是否有重复元素的方法小结

    本文实例讲述了JS判断数组里是否有重复元素的方法.分享给大家供大家参考,具体如下: 第一种方法:但是下面的这种方法数字字符串类似相同,返回的还是真,有点不靠谱,如果是其它的字符是可以的 var ary11 = new Array("1", "ff", "11", "aa", "2222"); // 验证重复元素,有重复返回true:否则返回false function mm(a) { return /(\x

  • 微信小程序常用赋值方法小结

    本文实例讲述了微信小程序常用赋值方法.分享给大家供大家参考,具体如下: 1.微信小程序将值赋值给局部变量: "=" 实例: var name=options.goodsName 2.微信小程序将值赋值给全局变量: "=" 或 this.setData({ }) 实例: this.data.goodName=options.goodsName this.setData({ goodName: options.goodsName }) 3.微信小程序将局部变量赋值给全局

  • PHP判断远程url是否有效的几种方法小结

    解决办法: 使用PHP解决 使用file_get_contents函数,不过优缺点如果url无法访问,会出现终止程序问题 使用curl返回,然后判断是否正确执行 使用get_headers函数,根据HTTP返回值查看是否有200 使用js解决: 使用原生的js函数ActiveXObject,仅支持ie内核的浏览器 使用jq扩展 本文主要介绍PHP解决办法中的第三种,这个方法很少用到,但是感觉又起来还不错, get_headers需要支持 php_openssl支持 查看phpinfo看看是否开启

  • js判断字符是否是汉字的两种方法小结

    有时需要判断一个字符是不是汉字,比如在用户输入含有中英文的内容时,需要判断是否超过规定长度就要用到.用 Javascript 判断通常有两种方法. 1.用正则表达式判断 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xml

随机推荐