지정 한 프로 세 스 나 프로그램 에 방법 소결 이 있 는 지 판단 하기(vc 등)

1.지정 한 프로그램 이름 의 프로 세 스 가 존재 하 는 지 판단 합 니 다.     BOOL EnumWindows( WNDENUMPROC lpEnumFunc, // pointer to callback function LPARAM lParam //   application-defined value);        EnumWindows 기능 은 핸들 을 각 창 에 전달 하여 화면의 모든 최상 위 창 을 차례로 애플 리 케 이 션 정의 콜백 기능 으로 열거 합 니 다.EnumWindows 는 마지막 최상 위 창 이 열거 되 거나 콜백 기능 이 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;
}
2.지정 한 프로 세 스 이름 의 프로 세 스 가 존재 하 는 지 판단 하기

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;
}
반환 값 이 0 이 아니라면 존재 하지 않 습 니 다.3.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);
}
4.VC 는 프로 세 스 가 존재 하 는 지 판단 합 니 다.예 를 들 어 나 는 수첩 이 실행 되 는 지,어떤 함 수 를 사용 해 야 하 는 지 알 고 싶다.4567913)모든 프로 세 스 의 프로그램 이름 을 매 거 진 다음 에 프로그램 이름 을 아 는 것 과 비교 판단 할 수 있다.5.프로그램 을 한 번 만 실행 하 는 방법        프로그램 을 한 번 만 실행 하 는 방법 은 많 지만 원 리 는 똑 같 습 니 다.첫 번 째 를 실행 할 때 표 시 를 설정 하고 실행 할 때마다 이 표 시 를 검사 하 는 것 입 니 다.있 으 면 이미 실행 되 었 다 는 것 을 설명 합 니 다.구체 적 실현:1.프로그램 초기 화 시   (InitInstance())   모든 창 을 열거 하여 이 프로그램의 인 스 턴 스 가 존재 하 는 지 찾 습 니 다.   2.주 창 이 초기 화 될 때 이 창의 속성 목록 에 프로그램 이 찾 을 수 있 도록 표 시 를 추가 합 니 다.일부 핵심 코드:1.App 의 InitInstance()에서 모든 창 을 열거 하고 이 프로그램의 인 스 턴 스

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;    
  }  
를 찾 습 니 다.2.EnumWNProc 창 프로 세 스 함수 추가:/추 가 된 표 지 는 한 번 만 실행 되 는 속성 명

HWND   oldHWnd   =   NULL;
EnumWindows(EnumWndProc,(LPARAM)&oldHWnd);  //
if(oldHWnd   !=   NULL)
{
AfxMessageBox( " ");
::ShowWindow(oldHWnd,SW_SHOWNORMAL);   //
::SetForegroundWindow(oldHWnd);       //
return   false;                       //
}
3.주 창 에 있 는 속성 명

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;
}
   OnInitDialog()에 속성 추가   //창 속성 설정 SetProp(mhWnd,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   변수   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;
}

좋은 웹페이지 즐겨찾기