TaskManager

所属分类:进程与线程
开发工具:Visual C++
文件大小:60KB
下载次数:85
上传日期:2012-10-13 09:48:05
上 传 者bsaver
说明:  VC6.0 制作的一个进程管理器,实现了当前进程的提取,新建进程,结束进程,内存、CPU利用率的动态图表显示
(VC6.0 produced by a process manager, the current process of extraction, the new process, the end of the process, memory, CPU utilization, dynamic charts show)

文件列表:
TaskManager\CPUInfo.h (1135, 2010-02-04)
TaskManager\MyCapad.cpp (9999, 2012-09-28)
TaskManager\MyCapad.h (1339, 2012-09-28)
TaskManager\MyOpen.cpp (1229, 2012-09-26)
TaskManager\MyOpen.h (1147, 2012-09-27)
TaskManager\MyProcess.cpp (5517, 2012-09-27)
TaskManager\MyProcess.h (1430, 2012-09-27)
TaskManager\MyProgram.cpp (3619, 2012-09-27)
TaskManager\MyProgram.h (1356, 2012-09-26)
TaskManager\psapi\PSAPI.DLL (18192, 2000-11-20)
TaskManager\psapi\PSAPI.H (4172, 1998-03-15)
TaskManager\psapi\Psapi.Lib (7458, 2012-09-27)
TaskManager\psapi (0, 2012-09-27)
TaskManager\res\Plasma1.ico (3774, 2012-09-26)
TaskManager\res\TaskManager.ico (4606, 2012-09-26)
TaskManager\res\TaskManager.rc2 (403, 2012-09-25)
TaskManager\res (0, 2012-09-26)
TaskManager\resource.h (1653, 2012-09-28)
TaskManager\StdAfx.cpp (213, 2012-09-25)
TaskManager\StdAfx.h (1120, 2012-09-27)
TaskManager\TaskManager.aps (41684, 2012-09-28)
TaskManager\TaskManager.clw (3251, 2012-10-08)
TaskManager\TaskManager.cpp (2133, 2012-09-25)
TaskManager\TaskManager.dsp (4890, 2012-09-28)
TaskManager\TaskManager.dsw (547, 2012-09-25)
TaskManager\TaskManager.h (1379, 2012-09-25)
TaskManager\TaskManager.ncb (82944, 2012-10-08)
TaskManager\TaskManager.opt (54784, 2012-10-08)
TaskManager\TaskManager.plg (1541, 2012-09-28)
TaskManager\TaskManager.rc (8049, 2012-09-28)
TaskManager\TaskManagerDlg.cpp (7439, 2012-09-26)
TaskManager\TaskManagerDlg.h (1778, 2012-09-26)
TaskManager (0, 2012-10-13)

//*****************************************************************************// //获取应用程序信息 //*****************************************************************************// 1:获取任务栏窗体 Wnd 的指针 CWnd* pWnd = AfxWindowGetMainWnd()->GetWindow(GW_HWNDFIRST); 2:判断窗体是否可访问、是否有标题、是否为子窗体 if(pWnd->IsWindowCisible() && pWnd->GetWindowTextLength() && !pWnd->GetOwner()) { } 3:获取任务栏窗体标题 pWnd->GetWindowText(strCaption); 4:利用循环遍历任务栏所有窗体 while(pWnd) { pWnd = pWnd->GetWindow(GW_HWNDNEXT); } //*****************************************************************************// //获取系统进程信息 //*****************************************************************************// 1:定义 PROCESSENTRY32 的结构体变量 process 用来保存进程信息 2:调用 CreateToolhelp32Snapshot() 返回当前系统进程快照,并定义一个句柄指向这个快照 HANDLE hProcess = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0); 3:根据进程快照,用 Process32First() 函数访问快照中的第一个进程,将信息保存在 process 中,访问结果放在 bool bMore 中 bool bMore = Process32First(hProcess,&process); 4:提取 PROCESSENTRY32 结构体中的有用信息 strReFlx.Format("%s",process.szExeFile); //提取进程名字 strID.Format("%5u",process.th32ProcessID); //获取进程ID strFID.Format("%u",process.th32ParentProcessID); //获取进程父ID 5:利用循环调用 Process32Next() 遍历进程 while(bMore) { bMore = Process32Next(hProcess,&process); } //*****************************************************************************// //获取进程内存使用信息信息 //*****************************************************************************// 1:定义一个 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc,用于保存内存使用信息 2:根据进程 ID 号调用 OpenProcess() 的函数打开指定的进程,并将句柄保存 HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ,FALSE,process.rh32ProcessID); 3:根据打开的进程句柄获取进程使用内存的信息,并将获取的信息保存到 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc 中 GetProcessMemoryInfo(hProcessl,&pmc,sizeof(pmc)); 4: 在 PROCESS_MEMORY_COUNTERS 的结构体变量 pmc 中,提取有用的内存信息,一个是最大进程使用内存空间,一个是实际使用内存大小 CurMem = pmc.WorkingSetSize / 1024; //实际占用内存空间大小 MaxMem = pmc.PeakWorkingSetSize / 1024; //最大占用内存空间大小 //*****************************************************************************// //如何启动、停止进程 //*****************************************************************************// 1:调用 ShellExecute() 函数来实现启动应用程序的进程,ShellExecute() 函数是运行一个外部程序(或是打开一个已经注册的文件、 打开一个目录、打印一个文件等),并对外部程序有一定的控制。原型如下: ShellExecute( HWND hwnd, //用于指定父窗口的句柄 LPCSTR lpOperation, //当函数调用过程中出现错误时,它将作为 Windows 消息窗口的父窗口 LPCSTR lpFile, //指定要打开的文件名或要执行程序的文件名,或是要浏览的文件夹名 LPCSTR lpParameters, //指定要进行的操作 LPCSTR lpDirectory, //用于指定默认目录 INT nShowCmd //指定程序窗口的初始化显示方式 ) example: ShellExecute(NULL,_T("open"),dlg.m_file,NULL,NULL,SW_SHOW); 2:关闭进程 //*****************************************************************************// //设置 ListCtrl 风格 //*****************************************************************************// -------------------------------------------------------------------------------- 1. CListCtrl 风格 LVS_ICON: 为每个item显示大图标 LVS_SMALLICON: 为每个item显示小图标 LVS_LIST: 显示一列带有小图标的item LVS_REPORT: 显示item详细资料 直观的理解:windows资源管理器,“查看”标签下的“大图标,小图标,列表,详细资料” -------------------------------------------------------------------------------- 2. 设置listctrl 风格及扩展风格 LONG lStyle; lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口style lStyle &= ~LVS_TYPEMASK; //清除显示方式位 lStyle |= LVS_REPORT; //设置style SetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置style DWORD dwStyle = m_list.GetExtendedStyle(); dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl) dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl) dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件 m_list.SetExtendedStyle(dwStyle); //设置扩展风格 -------------------------------------------------------------------------------- 3. 插入数据 m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列 m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 ); int nRow = m_list.InsertItem(0, “11”);//插入行 m_list.SetItemText(nRow, 1, “jacky”);//设置数据 -------------------------------------------------------------------------------- 4. 一直选中item 选中style中的Show selection always,或者在上面第2点中设置LVS_SHOWSELALWAYS -------------------------------------------------------------------------------- 5. 选中和取消选中一行 int nIndex = 0; //选中 m_list.SetItemState(nIndex, LVIS_SELECTED|LVIS_FOCUSED, LVIS_SELECTED|LVIS_FOCUSED); //取消选中 m_list.SetItemState(nIndex, 0, LVIS_SELECTED|LVIS_FOCUSED); -------------------------------------------------------------------------------- 6. 得到listctrl中所有行的checkbox的状态 m_list.SetExtendedStyle(LVS_EX_CHECKBOXES); CString str; for(int i=0; iGetItemCount(); -------------------------------------------------------------------------------- 12. 删除所有列 方法一: while ( m_list.DeleteColumn (0)) 因为你删除了第一列后,后面的列会依次向上移动。 方法二: int nColumns = 4; for (int i=nColumns-1; i>=0; i--) m_list.DeleteColumn (i); -------------------------------------------------------------------------------- 13. 得到单击的listctrl的行列号 添加listctrl控件的NM_CLICK消息相应函数 void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult) { // 方法一: /* DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); m_list.ScreenToClient(&point); LVHITTESTINFO lvinfo; lvinfo.pt = point; lvinfo.flags = LVHT_ABOVE; int nItem = m_list.SubItemHitTest(&lvinfo); if(nItem != -1) { CString strtemp; strtemp.Format("单击的是第%d行第%d列", lvinfo.iItem, lvinfo.iSubItem); AfxMessageBox(strtemp); } */ // 方法二: /* NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; if(pNMListView->iItem != -1) { CString strtemp; strtemp.Format("单击的是第%d行第%d列", pNMListView->iItem, pNMListView->iSubItem); AfxMessageBox(strtemp); } */ *pResult = 0; } -------------------------------------------------------------------------------- 14. 判断是否点击在listctrl的checkbox上 添加listctrl控件的NM_CLICK消息相应函数 void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult) { DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); m_list.ScreenToClient(&point); LVHITTESTINFO lvinfo; lvinfo.pt = point; lvinfo.flags = LVHT_ABOVE; UINT nFlag; int nItem = m_list.HitTest(point, &nFlag); //判断是否点在checkbox上 if(nFlag == LVHT_ONITEMSTATEICON) { AfxMessageBox("点在listctrl的checkbox上"); } *pResult = 0; } -------------------------------------------------------------------------------- 15. 右键点击listctrl的item弹出菜单 添加listctrl控件的NM_RCLICK消息相应函数 void CTest6Dlg::OnRclickList1(NMHDR* pNMHDR, LRESULT* pResult) { NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; if(pNMListView->iItem != -1) { DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); CMenu menu; VERIFY( menu.LoadMenu( IDR_MENU1 ) ); CMenu* popup = menu.GetSubMenu(0); ASSERT( popup != NULL ); popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, point.x, point.y, this ); } *pResult = 0; } -------------------------------------------------------------------------------- 16. item切换焦点时(包括用键盘和鼠标切换item时),状态的一些变化顺序 添加listctrl控件的LVN_ITEMCHANGED消息相应函数 void CTest6Dlg::OnItemchangedList1(NMHDR* pNMHDR, LRESULT* pResult) { NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; // TODO: Add your control notification handler code here CString sTemp; if((pNMListView->uOldState & LVIS_FOCUSED) == LVIS_FOCUSED && (pNMListView->uNewState & LVIS_FOCUSED) == 0) { sTemp.Format("%d losted focus",pNMListView->iItem); } else if((pNMListView->uOldState & LVIS_FOCUSED) == 0 && (pNMListView->uNewState & LVIS_FOCUSED) == LVIS_FOCUSED) { sTemp.Format("%d got focus",pNMListView->iItem); } if((pNMListView->uOldState & LVIS_SELECTED) == LVIS_SELECTED && (pNMListView->uNewState & LVIS_SELECTED) == 0) { sTemp.Format("%d losted selected",pNMListView->iItem); } else if((pNMListView->uOldState & LVIS_SELECTED) == 0 && (pNMListView->uNewState & LVIS_SELECTED) == LVIS_SELECTED) { sTemp.Format("%d got selected",pNMListView->iItem); } *pResult = 0; } -------------------------------------------------------------------------------- 17. 得到另一个进程里的listctrl控件的item内容 http://www.codeproject.com/threads/int***_memsteal.asp -------------------------------------------------------------------------------- 18. 选中listview中的item Q131284: How To Select a Listview Item Programmatically http://support.microsoft.com/kb/131284/en-us -------------------------------------------------------------------------------- 19. 如何在CListView中使用CListCtrl的派生类 http://www.codeguru.com/cpp/controls/listview/introduction/article.php/c919/ -------------------------------------------------------------------------------- 20. listctrl的subitem添加图标 m_list.SetExtendedStyle(LVS_EX_SUBITEMIMAGES); m_list.SetItem(..); //具体参数请参考msdn -------------------------------------------------------------------------------- 21. 在CListCtrl显示文件,并根据文件类型来显示图标 网上找到的代码,share BOOL CTest6Dlg::OnInitDialog() { CDialog::OnInitDialog(); HIMAGELIST himlSmall; HIMAGELIST himlLarge; SHFILEINFO sfi; char cSysDir[MAX_PATH]; CString strBuf; memset(cSysDir, 0, MAX_PATH); GetWindowsDirectory(cSysDir, MAX_PATH); strBuf = cSysDir; sprintf(cSysDir, "%s", strBuf.Left(strBuf.Find("\\")+1)); himlSmall = (HIMAGELIST)SHGetFileInfo ((LPCSTR)cSysDir, 0, &sfi, sizeof(SHFILEINFO), SHGFI_SYSICONINDEX | SHGFI_SMALLICON ); himlLarge = (HIMAGELIST)SHGetFileInfo((LPCSTR)cSysDir, 0, &sfi, sizeof(SHFILEINFO), SHGFI_SYSICONINDEX | SHGFI_LARGEICON); if (himlSmall && himlLarge) { ::SendMessage(m_list.m_hWnd, LVM_SETIMAGELIST, (WPARAM)LVSIL_SMALL, (LPARAM)himlSmall); ::SendMessage(m_list.m_hWnd, LVM_SETIMAGELIST, (WPARAM)LVSIL_NORMAL, (LPARAM)himlLarge); } return TRUE; // return TRUE unless you set the focus to a control } void CTest6Dlg::AddFiles(LPCTSTR lpszFileName, BOOL bAddToDocument) { int nIcon = GetIconIndex(lpszFileName, FALSE, FALSE); CString strSize; CFileFind filefind; // get file size if (filefind.FindFile(lpszFileName)) { filefind.FindNextFile(); strSize.Format("%d", filefind.GetLength()); } else strSize = "0"; // split path and filename CString strFileName = lpszFileName; CString strPath; int nPos = strFileName.ReverseFind('\\'); if (nPos != -1) { strPath = strFileName.Left(nPos); strFileName = strFileName.Mid(nPos + 1); } // insert to list int nItem = m_list.GetItemCount(); m_list.InsertItem(nItem, strFileName, nIcon); m_list.SetItemText(nItem, 1, strSize); m_list.SetItemText(nItem, 2, strFileName.Right(3)); m_list.SetItemText(nItem, 3, strPath); } int CTest6Dlg::GetIconIndex(LPCTSTR lpszPath, BOOL bIsDir, BOOL bSelected) { SHFILEINFO sfi; memset(&sfi, 0, sizeof(sfi)); if (bIsDir) { SHGetFileInfo(lpszPath, FILE_ATTRIBUTE_DIRECTORY, &sfi, sizeof(sfi), SHGFI_SMALLICON | SHGFI_SYSICONINDEX | SHGFI_USEFILEATTRIBUTES |(bSelected ? SHGFI_OPENICON : 0)); return sfi.iIcon; } else { SHGetFileInfo (lpszPath, FILE_ATTRIBUTE_NORMAL, &sfi, sizeof(sfi), SHGFI_SMALLICON | SHGFI_SYSICONINDEX | SHGFI_USEFILEATTRIBUTES | (bSelected ? SHGFI_OPENICON : 0)); return sfi.iIcon; } return -1; } -------------------------------------------------------------------------------- 22. listctrl内容进行大数据量更新时,避免闪烁 m_list.SetRedraw(FALSE); //更新内容 m_list.SetRedraw(TRUE); m_list.Invalidate(); m_list.UpdateWindow(); 或者参考 http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vclib/html/_mfc_cwnd.3a3a.setredraw.asp //*****************************************************************************// //解决 list 闪烁 //*****************************************************************************// 设: 控件名称:m_List 1.先锁定窗口,不进行刷新 m_List.LockWindowUpdate(); 2.设定列表不进行重画 m_List.SetRedraw(FALSE); www.2cto.com 3.清空列表,删除历史数据 m_List.DeleteAllItems(); 4.窗口解锁,允许刷新。否则系统的视图也会进行闪烁 m_List.UnlockWindowUpdate(); 5.向列表中循环增加记录 m_List.InsertItems(); 6.重画列表 m_List.SetRedraw(TRUE);

近期下载者

相关文件


收藏者