因为任务管理器中涉及到进程的枚举操作,所以把两节课的知识点合并到一起来讲!
 
①、设计界面、以及列表控件变量的绑定;
②、列表控件样式的指定:
m_TaskList.SetExtendedStyle(LVS_EX_GRIDLINES | LVS_EX_FULLROWSELECT);
m_TaskList.InsertColumn(0, _T(" 进程名称"), 0, 100);
m_TaskList.InsertColumn(1, _T(" PID"), 0, 60);
m_TaskList.InsertColumn(2, _T(" 文件路径"), 0, 380);
 
③、进程列表的获取:
具体的方法也是多种的,具体见:http://www.cctry.com/thread-11857-1-1.html
这里面我们使用第一种方法给大家讲解:
 
#include <Tlhelp32.h>
#include <Psapi.h>
#pragma comment(lib, "Psapi.lib")
BOOL CMFCTestDlg::GetProcessList()
{
 BOOL bResult = FALSE;
 HANDLE hSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
 if ( hSnap == INVALID_HANDLE_VALUE )
  return FALSE;
 
 int idx = 0;
 CString strID;
 HANDLE hProcess = NULL;
 PROCESSENTRY32 info = {0};
 info.dwSize = sizeof(PROCESSENTRY32);
 
 BOOL bRet = Process32First(hSnap, &info);
 while(bRet) {
  idx = m_TaskList.InsertItem(m_TaskList.GetItemCount(), _T(""));
  m_TaskList.SetItemText(idx, 0, info.szExeFile);
  strID.Empty();
  strID.Format(_T("%d"), info.th32ProcessID);
  m_TaskList.SetItemText(idx, 1, strID);
 
  hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, info.th32ProcessID);
  if (hProcess) {
   TCHAR szPath[MAX_PATH] = {0};
   GetModuleFileNameEx(hProcess, NULL, szPath, MAX_PATH);
   m_TaskList.SetItemText(idx, 2, szPath);
  }
  bRet = Process32Next(hSnap, &info);
 }
 return TRUE;
}
 
④、Debug 权限提升函数:
BOOL AdjustPrivileges()
{
 HANDLE hToken = NULL;
 TOKEN_PRIVILEGES tp = {0};
 TOKEN_PRIVILEGES oldtp = {0};
 DWORD dwSize = sizeof(TOKEN_PRIVILEGES);
 LUID luid = {0};
 
 if (!OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken)) {
  if (GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
   return TRUE;
  else
   return FALSE;
 }
 if (!LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &luid)) {
  CloseHandle(hToken);
  return FALSE;
 }
 
 tp.PrivilegeCount=1;
 tp.Privileges[0].Luid = luid;
 tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
 
 /* Adjust Token Privileges */
 if (!AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(TOKEN_PRIVILEGES), &oldtp, &dwSize)) {
  CloseHandle(hToken);
  return FALSE;
 }
 
 // close handles
 CloseHandle(hToken);
 return TRUE;
}
 
⑤、菜单资源的添加及编辑:
刷新列表:ID_M_REFRESH_LIST
结束此进程:ID_M_EDN_TASK
定位文件:ID_M_FIND_EXE
拷贝路径:ID_M_COPY_PATH
 
⑥、菜单资源的弹出:
void CMFCTestDlg::OnNMRClickTaskList(NMHDR *pNMHDR, LRESULT *pResult)
{
 LPNMITEMACTIVATE pNMItemActivate = reinterpret_cast<LPNMITEMACTIVATE>(pNMHDR);
 if ( pNMItemActivate->iItem < 0 ) return;
 
 CString strID = m_TaskList.GetItemText(pNMItemActivate->iItem, 1);
 
 CPoint pt;
 GetCursorPos(&pt);
 CMenu mMenu, *pMenu;
 mMenu.LoadMenu(IDR_MENU);
 pMenu = mMenu.GetSubMenu(0);
 if (strID == _T("0") || strID == _T("4")){
  pMenu->EnableMenuItem(ID_M_EDN_TASK, MF_BYCOMMAND|MF_GRAYED);
  pMenu->EnableMenuItem(ID_M_FIND_EXE, MF_BYCOMMAND|MF_GRAYED);
  pMenu->EnableMenuItem(ID_M_COPY_PATH, MF_BYCOMMAND|MF_GRAYED);
 }
 pMenu->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, pt.x, pt.y, this);
 
 *pResult = 0;
}
 
⑦、菜单响应函数的实现:
void CMFCTestDlg::OnMRefreshList()
{
 for (int idx = 0; idx < m_ImgList.GetImageCount(); idx++) {
  m_ImgList.Remove(idx);
 }
 
 m_TaskList.DeleteAllItems();
 GetProcessList();
}
 
void CMFCTestDlg::OnMEdnTask()
{
 int idx = m_TaskList.GetSelectionMark();
 CString strID = m_TaskList.GetItemText(idx, 1);
 CString strName = m_TaskList.GetItemText(idx, 0);
 
 int iRet = MessageBox(_T("您确定要结束 ")+strName+_T(" 吗?"), _T("友情提示"), MB_OKCANCEL);
 if (iRet == IDCANCEL) return;
 
 if ( strID == _T("0") || strName == _T("4")) { //实际上这个位置的判断是多余的
  MessageBox(_T("系统进程,无法结束!"), _T("提示"));
 }else{
  BOOL bRet = FALSE;
  HANDLE hProcess = OpenProcess(PROCESS_TERMINATE|PROCESS_QUERY_INFORMATION, FALSE, _tstoi(strID));
  if ( hProcess != NULL ) {
   bRet = TerminateProcess(hProcess, -1);
   CloseHandle(hProcess);
  }
 
  if ( !bRet ) {
   MessageBox(_T("结束进程 \" ") + strName + _T(" \" 失败,请重试!"), _T("提示"));
  }else{
   m_TaskList.DeleteItem(idx);
  }
 }
}
 
void CMFCTestDlg::OnMFindExe()
{
 int idx = m_TaskList.GetSelectionMark();
 CString strPath = m_TaskList.GetItemText(idx, 2);
 if (strPath.GetLength() > 0)
  ShellExecute(m_hWnd, _T("open"), _T("Explorer.exe"), _T("/select,")+strPath, NULL, SW_SHOW);
}
 
void CMFCTestDlg::OnMCopyPath()
{
 int idx = m_TaskList.GetSelectionMark();
 CString strPath = m_TaskList.GetItemText(idx, 2);
 
 if (!OpenClipboard()) return;
 if(!EmptyClipboard()) {
  CloseClipboard();
  return;
 }
 
 size_t cbStr = (strPath.GetLength()+1)*sizeof(TCHAR);
 HGLOBAL hData = GlobalAlloc(GMEM_MOVEABLE, cbStr);
 memcpy_s(GlobalLock(hData), cbStr, strPath.LockBuffer(), cbStr);
 GlobalUnlock(hData);
 strPath.UnlockBuffer();
 
 UINT uiFormat = (sizeof(TCHAR) == sizeof(WCHAR)) ? CF_UNICODETEXT : CF_TEXT;
 if (::SetClipboardData(uiFormat, hData) == NULL) {
  MessageBox(_T("设置剪贴板数据失败!"));
  CloseClipboard();
  return;
 }
 
 CloseClipboard();
}
 
⑧、为列表控件加上程序的前缀图标:
// H 头文件中进行图像列表的定义:
CImageList m_ImgList;
 
// OnInitDialog() 函数中进行图像列表的创建及设置:
m_ImgList.Create(16, 16, ILC_COLOR24, 10, 10);
m_TaskList.SetImageList(&m_ImgList, LVSIL_SMALL);
 
⑨、修改GetProcessList()函数为如下:
BOOL CMFCTestDlg::GetProcessList()
{
 BOOL bResult = FALSE;
 HANDLE hSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
 if ( hSnap == INVALID_HANDLE_VALUE )
  return FALSE;
 
 int idx = 0, imgIdx = -1;
 CString strID;
 HANDLE hProcess = NULL;
 CString strPath, strSys(_T("SystemRoot"));
 PROCESSENTRY32 info = {0};
 info.dwSize = sizeof(PROCESSENTRY32);
 
 BOOL bRet = Process32First(hSnap, &info);
 while(bRet) {
  hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, info.th32ProcessID);
  if (hProcess) {
   strPath.Empty();
   GetModuleFileNameEx(hProcess, NULL, strPath.GetBufferSetLength(MAX_PATH), MAX_PATH);
   strPath.ReleaseBuffer();
   strPath.TrimLeft(_T("\\?"));
   if (strPath.Left(strSys.GetLength()).CompareNoCase(strSys) == 0){
    TCHAR szWin[MAX_PATH] = {0};
    GetWindowsDirectory(szWin, MAX_PATH);
    strPath.Replace(strSys, szWin);
   }
 
   SHFILEINFO shInfo = {0};
   SHGetFileInfo(strPath, 0, &shInfo, sizeof(SHFILEINFO), SHGFI_SMALLICON|SHGFI_ICON);
   imgIdx = m_ImgList.Add(shInfo.hIcon);
  }
 
  //进行列表项的插入
  idx = m_TaskList.InsertItem(m_TaskList.GetItemCount(), _T(""), imgIdx);
  m_TaskList.SetItemText(idx, 0, info.szExeFile);
  strID.Empty();
  strID.Format(_T("%d"), info.th32ProcessID);
  m_TaskList.SetItemText(idx, 1, strID);
  m_TaskList.SetItemText(idx, 2, strPath);
 
  //继续遍历进程列表
  bRet = Process32Next(hSnap, &info);
 }
 
 return TRUE;
}
 
 
1、使用 EnumProcesses 函数进行进程的枚举;
2、针对选中多个进程进行结束时的处理!
 

vc++基础班[27]---实现一个简单的任务管理器的更多相关文章

  1. vc++基础班[24]---系统各种路径信息的获取

    vc++基础班[24]---系统各种路径信息的获取 ------------------------------------------ Begin ------------------------- ...

  2. vc++基础班[25]---系统信息的获取

    --------------------------------------------------------------------------- VC 驿站 WwW.CcTry.CoM 多抽出一 ...

  3. vc++基础班[28]---动态数组及动态链表的讲解

    C++中也有相应的动态数组.动态链表.映射表的模板类,就是STL中的:vector.list.map 他们属于C++标准中的一部分,对于程序的移植性来说也是不错的,但是在MFC编程中使用 CArray ...

  4. vc++基础班[26]---进程的相关操作

      ①.ShellExecute 进行进程的创建,属于 shell api: //int iRet = (int)ShellExecute(m_hWnd, _T("open"), ...

  5. vc++基础班[23]---文件夹的基本操作

      ①.文件夹的创建:CreateDirectory ※※※ 注意:此函数只能创建一层目录,比如想在 C 盘下的 Temp 目录下创建新目录为:123 那么前提是 Temp 这个目录存在才可以!   ...

  6. vc++基础班[22]---文件的基本操作2

      MFC 中的 CFile 及其派生类中没有提供直接进行文件的复制操作,因而要借助于SDK API: SDK中的文件相关函数常用的有CopyFile().CreateDirectory().Dele ...

  7. vc++基础班[21]---文件的基本操作之CFile

    ①.文件的创建.打开.关闭: 文件的创建.打开:CFile::Open 文件的关闭:CFile::Close   CFile::modeCreate:以新建方式打开,如果文件不存在,则新建:如果文件已 ...

  8. PHP基础班初学感悟

    不知不觉差不多一个月就过去了 刚到培训班那时候的心情,现在也还能有所感觉 作为今年6月份的毕业生,刚从大学的实习期出来,辞掉了上一份工作,本来是打算找一份更加与专业挂钩的工作做的 也许是90后对网络的 ...

  9. 【SpringBoot 基础系列】实现一个自定义配置加载器(应用篇)

    [SpringBoot 基础系列]实现一个自定义配置加载器(应用篇) Spring 中提供了@Value注解,用来绑定配置,可以实现从配置文件中,读取对应的配置并赋值给成员变量:某些时候,我们的配置可 ...

随机推荐

  1. centos之Too many open files问题-修改linux最大文件句柄数

    linux服务器大并发调优时,往往需要预先调优linux参数,其中修改linux最大文件句柄数是最常修改的参数之一. 在linux中执行ulimit -a 即可查询linux相关的参数,如下所示: [ ...

  2. Office-kms

    Office 2016 VOL Office Office 2016 Pro Plus 32 位专业增强版 文件名 SW_DVD5_Office_Professional_Plus_2016_W32_ ...

  3. canvas加载图片需要二次刷新的问题

    如题:此问题我也经在百度问问上进行了解答.https://zhidao.baidu.com/question/1048045241465845579.html 好吧,难怪现在百度那么坑人,理论水军专家 ...

  4. Hadoop完全分布式安装

    一.软件版本 Hadoop版本号:hadoop-2.6.0.tar: VMWare版本号:VMware-workstation-full-11.0.0-2305329 Ubuntu版本号:ubuntu ...

  5. hdu 6383

    题意是说给定一个序列,能否通过任意次对部分数字 +1,对部分数字 -2的操作使得序列在满足全部非负且任意两元素的差值不超过1的前提下最小值最大,求最大值. 一开始的时候没有注意到整个序列全是非负数,还 ...

  6. 02-Unity深入浅出(二)

    一. Unity声明周期 Unity容器为我们提供了6种生命周期,便于我们根据项目需求来选择使用. (1). 瞬时.默认省略即为瞬时,无论单线程还是多线程,每次都重新创建对象.new Transien ...

  7. python模块之logging模块

    1. 低配版 # 指定显示信息格式 import logging logging.basicConfig( level=20, # 设置显示或写入的起始级别 format="%(asctim ...

  8. mkdocs 生成帮助文档

    简介 MkDocs 可以同时编译多个markdown文件,形成书籍一样的文件.有多种主题供你选择,很适合项目使用. MkDocs 是快速,简单和华丽的静态网站生成器,可以构建项目文档.文档源文件在 M ...

  9. Linux下的解压命令

    Linux下常见的压缩包格式有5种:zip tar.gz tar.bz2 tar.xz tar.Z 其中tar是种打包格式,gz和bz2等后缀才是指代压缩方式:gzip和bzip2 filename. ...

  10. UVAlive 6697 Homework Evaluation

    借鉴了别人的博客啊,自己写写给以后的自己看吧 给出两个字符串,用第二个字符串去匹配第一个字符串,可以对第二个字符串进行删除或插入操作,一位匹配成功得8分失败-5分,如果插入或删除,对于连续插入或删除m ...