操作系統(tǒng)課程設(shè)計(jì)---windows系統(tǒng)資源管理器與任務(wù)管理器_第1頁(yè)
已閱讀1頁(yè),還剩47頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  XX大學(xué)課程設(shè)計(jì)報(bào)告</p><p>  課程設(shè)計(jì)題目: Windows系統(tǒng)資源管理器與任務(wù)管理器 </p><p>  學(xué) 院: </p><p>  專(zhuān)業(yè)班級(jí):

2、 </p><p>  年 級(jí): 2008級(jí) </p><p>  姓 名: </p><p>  學(xué) 號(hào): </p>&l

3、t;p>  完成時(shí)間: 2012 年 7 月 3 日</p><p>  成 績(jī): </p><p>  指導(dǎo)教師: </p><p><b>  教務(wù)處</b></p><

4、;p><b>  課程設(shè)計(jì)任務(wù)書(shū)</b></p><p><b>  摘 要</b></p><p>  操作系統(tǒng)是一個(gè)介于軟件和硬件之間的特殊硬件,一方面分配硬件資源另一方面支持軟件在它上面的實(shí)現(xiàn),如何實(shí)時(shí)地監(jiān)控和掌握系統(tǒng)軟硬件工作的狀態(tài)、資源分配和使用的情況,對(duì)計(jì)算機(jī)用戶而言十分重要,于是就有了任務(wù)管理器這樣的實(shí)時(shí)監(jiān)控窗口;同理,

5、我們也需要掌握計(jì)算機(jī)硬件設(shè)備的工作狀態(tài),掌握其如何存儲(chǔ)文件、分配硬盤(pán)資源等,這也是我們做資源管理器的初衷。</p><p>  我們的電腦需要我們?nèi)チ私馑倪\(yùn)行狀況,掌握和管理它的進(jìn)程,并對(duì)其異常情況給予操作和控制,任務(wù)管理器就像是我們了解和控制自己電腦運(yùn)作的一個(gè)窗口,通過(guò)這個(gè)窗口我們可以了解到電腦所有進(jìn)程運(yùn)行狀況,并對(duì)運(yùn)行的進(jìn)程加于管理和控制,正如在本實(shí)驗(yàn)中,啟動(dòng)進(jìn)程管理器后,可以通過(guò)”獲取進(jìn)程”功能來(lái)獲得本計(jì)

6、算機(jī)啟動(dòng)的進(jìn)程,以及與該進(jìn)程相關(guān)的信息,其中包括的信息有:進(jìn)程映像名稱(chēng),進(jìn)程開(kāi)啟的線程數(shù),進(jìn)程的PID以及進(jìn)程的優(yōu)先數(shù),我們可以通過(guò)這些信息來(lái)了解計(jì)算機(jī)中每個(gè)進(jìn)程的使用狀況。同時(shí)我們可以在進(jìn)程管理器上選中一個(gè)要終止的的進(jìn)程,點(diǎn)擊“終止進(jìn)程”功能按鈕,該進(jìn)程被終止執(zhí)行并退出進(jìn)程列表,其中還包括了自動(dòng)刷新的功能,此按鈕實(shí)現(xiàn)的功能正如我們電腦任務(wù)管理器的“進(jìn)程”功能,當(dāng)電腦執(zhí)行程序不能通過(guò)關(guān)閉窗口進(jìn)行正常的關(guān)閉時(shí),可以借助此辦法來(lái)關(guān)閉進(jìn)程。我

7、們還可以通過(guò)這個(gè)進(jìn)程管理器來(lái)啟動(dòng)新的進(jìn)程,當(dāng)我們要在進(jìn)程管理器里啟動(dòng)新的進(jìn)程時(shí),只要點(diǎn)擊“啟動(dòng)新進(jìn)程”按鍵,則會(huì)彈出“打開(kāi)進(jìn)程”對(duì)話框,我們可以通過(guò)對(duì)話框里的“瀏覽”窗口選擇要打開(kāi)的新進(jìn)程,這是任務(wù)管理器里沒(méi)有實(shí)現(xiàn)的功能,通過(guò)這個(gè)功能我們?cè)诠芾碛?jì)算機(jī)時(shí)變得更加靈活方便,也</p><p>  關(guān)鍵詞:任務(wù)管理器 資源管理器 操作系統(tǒng)</p><p><b>  課程設(shè)計(jì)要求<

8、;/b></p><p>  題目名稱(chēng):Windows系統(tǒng)資源管理器與任務(wù)管理器</p><p><b>  題目類(lèi)型:設(shè)計(jì)型</b></p><p>  課程設(shè)計(jì)目的:熟悉操作系統(tǒng)資源管理原理,掌握編程接口,能夠使用高級(jí)語(yǔ)言調(diào)用編程接口,設(shè)計(jì)并實(shí)現(xiàn)Windows操作系統(tǒng)資源管理器和任務(wù)管理器的全部功能。</p><p

9、>  已知參數(shù)和設(shè)計(jì)要求:</p><p>  熟悉操作系統(tǒng)資源管理原理,掌握編程接口,能夠使用高級(jí)語(yǔ)言調(diào)用編程接口,設(shè)計(jì)并實(shí)現(xiàn)Windows操作系統(tǒng)資源管理器的全部功能(包括:菜單、圖標(biāo)、右鍵菜單),實(shí)現(xiàn)軟件資源和數(shù)據(jù)資源的管理;</p><p>  掌握操作系統(tǒng)任務(wù)與進(jìn)程概念,熟悉任務(wù)與進(jìn)程管理的方法,通過(guò)高級(jí)語(yǔ)言編程接口設(shè)計(jì)并實(shí)現(xiàn)Windows操作系統(tǒng)任務(wù)管理器的全部功能(包括

10、:菜單、右鍵菜單、應(yīng)用程序管理、進(jìn)程管理、性能顯示、聯(lián)網(wǎng)狀態(tài)和用戶信息)。</p><p><b>  實(shí)驗(yàn)內(nèi)容:</b></p><p>  了解Windows操作系統(tǒng)的發(fā)展歷史;</p><p>  了解Windows XP的體系結(jié)構(gòu);</p><p>  掌握Windows系統(tǒng)API的調(diào)用方法;</p>

11、<p>  設(shè)計(jì)并實(shí)現(xiàn)Windows操作系統(tǒng)資源管理器的全部功能(包括:菜單、圖標(biāo)、右鍵菜單),實(shí)現(xiàn)軟件資源和數(shù)據(jù)資源的管理;</p><p>  設(shè)計(jì)并實(shí)現(xiàn)Windows操作系統(tǒng)任務(wù)管理器的全部功能(包括:菜單、右鍵菜單、應(yīng)用程序管理、進(jìn)程管理、性能顯示、聯(lián)網(wǎng)狀態(tài)和用戶信息)。</p><p><b>  設(shè)計(jì)概要</b></p><

12、;p><b>  2.1功能設(shè)計(jì)</b></p><p>  本項(xiàng)目是為了實(shí)現(xiàn)模擬Windows系統(tǒng)任務(wù)管理器和資源管理器。項(xiàng)目的分析及功能設(shè)計(jì)要求如下:</p><p>  編程模擬實(shí)現(xiàn)Windows系統(tǒng)任務(wù)管理器和資源管理器兩個(gè)應(yīng)用程序;</p><p>  服務(wù)器端可以對(duì)文件進(jìn)行管理,包括上傳,下載,刪除文件,重命名等;</p

13、><p>  客服端可以實(shí)現(xiàn)文件的上傳、下載以及查看服務(wù)器下默認(rèn)目錄的文件列表;</p><p>  在程序中應(yīng)用多線程來(lái)實(shí)現(xiàn)多個(gè)客戶端同時(shí)對(duì)一個(gè)服務(wù)器端進(jìn)行請(qǐng)求操作。</p><p>  2.2程序系統(tǒng)功能模塊</p><p>  2.2.1 Windows任務(wù)管理器功能模塊</p><p><b>  圖2.

14、1</b></p><p>  2.2.2 Windows資源管理器功能模塊</p><p><b>  圖2.2</b></p><p><b>  2.3功能分析</b></p><p>  2.3.1 Windows任務(wù)管理器功能流程圖</p><p>&l

15、t;b>  圖2.3</b></p><p>  2.3.2 Windows資源管理器功能流程圖</p><p><b>  圖2.4</b></p><p>  2.3.3 Windows任務(wù)管理器界面截圖</p><p><b>  整體界面</b></p>&l

16、t;p><b>  不同狀態(tài)顯示的截圖</b></p><p>  2.3.4 Windows資源管理器界面截圖</p><p><b>  整體界面:</b></p><p><b>  2、功能界面展示:</b></p><p><b>  “文件”功能展示

17、</b></p><p><b>  “編輯”功能展示</b></p><p><b>  “視圖”功能展示</b></p><p><b>  “幫助”功能展示</b></p><p>  2.3.5 程序主要功能說(shuō)明</p><p> 

18、 一、Windows任務(wù)管理器主要功能代碼實(shí)現(xiàn):</p><p><b>  '獲得進(jìn)程代碼實(shí)現(xiàn)</b></p><p>  Public Sub ListProcess()</p><p>  On Error Resume Next</p><p>  Dim i As Long, j As Long, n

19、As Long</p><p>  Dim proc As PROCESSENTRY32</p><p>  Dim snap As Long</p><p>  Dim exename As String '應(yīng)用程序名</p><p>  Dim item As ListItem</p><p>  Di

20、m lngHwndProcess As Long</p><p>  Dim lngModules(1 To 200) As Long</p><p>  Dim lngCBSize2 As Long</p><p>  Dim lngReturn As Long</p><p>  Dim strModuleName As String&l

21、t;/p><p>  Dim pmc As PROCESS_MEMORY_COUNTERS</p><p>  Dim WKSize As Long</p><p>  Dim strProcessName As String</p><p>  Dim strComment As String '裝載進(jìn)程注釋的字符串</p&g

22、t;<p>  Dim ProClass As String '程序的類(lèi)名</p><p><b>  '開(kāi)始進(jìn)程循環(huán)</b></p><p>  snap = CreateToolhelpSnapshot(TH32CS_SNAPall, 0)</p><p>  proc.dwSize = Len(proc)

23、</p><p>  theloop = ProcessFirst(snap, proc)</p><p><b>  i = 0</b></p><p><b>  n = 0</b></p><p>  While theloop <> 0</p><p>&

24、lt;b>  i = i + 1</b></p><p>  '打開(kāi)指定的進(jìn)程序,并得到進(jìn)程的句柄</p><p>  lngHwndProcess = OpenProcess(PROCESS_QUERY_INFORMATION Or PROCESS_VM_READ, 0, proc.th32ProcessID)</p><p>  If

25、lngHwndProcess <> 0 Then</p><p>  '枚舉系統(tǒng)中正在運(yùn)行的進(jìn)程模板</p><p>  lngReturn = EnumProcessModules(lngHwndProcess, lngModules(1), 200, lngCBSize2)</p><p>  If lngReturn <> 0

26、Then</p><p>  '返回特定數(shù)目空格的</p><p>  strModuleName = Space(MAX_PATH)</p><p>  '獲取一個(gè)已裝載模板的完整路徑名稱(chēng)</p><p>  lngReturn = GetModuleFileNameExA(lngHwndProcess, lngModule

27、s(1), strModuleName, 500)</p><p>  strProcessName = Left(strModuleName, lngReturn)</p><p>  strProcessName = CheckPath(Trim$(strProcessName))</p><p>  If strProcessName <> &qu

28、ot;" Then</p><p>  '判斷ITEM是否已經(jīng)存在</p><p>  j = HaveItem(proc.th32ProcessID)</p><p>  If j = 0 Then '如果沒(méi)有該進(jìn)程</p><p><b>  '獲取短文件名</b></p&g

29、t;<p>  exename = Dir(strProcessName, vbNormal Or vbHidden Or vbReadOnly Or vbSystem)</p><p>  If exename = "hh.exe" Then</p><p>  'MsgBox SetProClass(proc.th32ProcessID, ID

30、LE_PRIORITY_CLASS)</p><p><b>  End If</b></p><p><b>  '添加進(jìn)程item</b></p><p>  Set item = List1.ListItems.Add(, "ID:" & CStr(proc.th32Process

31、ID), exename)</p><p><b>  '進(jìn)程ID</b></p><p>  item.SubItems(1) = proc.th32ProcessID</p><p><b>  '內(nèi)存使用</b></p><p>  pmc.cb = LenB(pmc)<

32、/p><p>  '獲得進(jìn)程的內(nèi)存信息,在這里就是計(jì)算該進(jìn)程占用內(nèi)存多少</p><p>  lret = GetProcessMemoryInfo(lngHwndProcess, pmc, pmc.cb)</p><p>  n = n + pmc.WorkingSetSize</p><p>  WKSize = pmc.Workin

33、gSetSize / 1024</p><p>  item.SubItems(3) = WKSize & " K"</p><p><b>  '進(jìn)程序IP號(hào)</b></p><p>  item.SubItems(2) = GetProClass(proc.th32ProcessID)</p>

34、<p>  '進(jìn)程圖標(biāo)將獲取的圖標(biāo)加到IMAGE控件中</p><p>  IM1.ListImages.Add , strProcessName, GetIcon(strProcessName)</p><p>  item.SmallIcon = IM1.ListImages.item(strProcessName).Key</p><p>

35、;  Else '如果已經(jīng)有該進(jìn)程</p><p>  pmc.cb = LenB(pmc)</p><p>  '獲得進(jìn)程的內(nèi)存信息,在這里就是計(jì)算該進(jìn)程占用內(nèi)存多少</p><p>  lret = GetProcessMemoryInfo(lngHwndProcess, pmc, pmc.cb)</p><p> 

36、 n = n + pmc.WorkingSetSize</p><p>  WKSize = pmc.WorkingSetSize / 1024 '計(jì)算占用內(nèi)存</p><p>  If CLng(List1.ListItems.item(j).SubItems(3)) <> WKSize Then List1.ListItems.item(j).SubItems(3

37、) = WKSize & " K"</p><p><b>  '獲得進(jìn)程的類(lèi)名</b></p><p>  ProClass = GetProClass(proc.th32ProcessID)</p><p>  If ProClass <>List1.ListItems.item(j).Sub

38、Items(5) Then List1.ListItems.item(j).SubItems(5) = ProClass</p><p><b>  End If</b></p><p><b>  End If</b></p><p><b>  End If</b></p><

39、p><b>  End If</b></p><p>  theloop = ProcessNext(snap, proc)</p><p><b>  Wend</b></p><p>  CloseHandle snap</p><p>  '顯示總進(jìn)程數(shù) Label3</p

40、><p>  If i <> ProCount Then</p><p>  Label3.Caption = "進(jìn)程數(shù):" & i</p><p>  ProCount = i</p><p><b>  End If</b></p><p>  If n &

41、lt;> RamUse Then '這里的"130"是后來(lái)加上去的.是為了和系統(tǒng)自帶的數(shù)值一樣</p><p>  Label5.Caption = Val(FormatLng(n)) + 130 & "MB"</p><p>  RamUse = n</p><p>  For i = 950

42、To Val(FormatLng(n)) + 400 Step -90</p><p>  rampic.Line (0, i)-Step(1200, 20), &HFF00&, BF</p><p><b>  Next i</b></p><p><b>  End If</b></p>

43、<p><b>  End Sub</b></p><p>  '調(diào)用系統(tǒng)的"關(guān)于"窗</p><p>  Private Sub about_Click()</p><p>  On Error Resume Next</p><p>  ShellAbout Me.hwnd, A

44、pp.Title, "譚建&文程&張?jiān)?quot;, ByVal 0&</p><p><b>  End Sub</b></p><p><b>  '退出本程序員</b></p><p>  Private Sub close_Click()</p><p&

45、gt;  tmrRefresh.Enabled = False</p><p><b>  Unload Me</b></p><p><b>  End Sub</b></p><p>  Private Sub CloseSystem_Click()</p><p>  tmrRefresh.E

46、nabled = False</p><p><b>  Unload Me</b></p><p><b>  End Sub</b></p><p><b>  '應(yīng)用程序切換程序</b></p><p>  Private Sub cmdSwitch_Click(

47、)</p><p>  Dim hwnd As Long</p><p>  Dim X As Long</p><p>  Dim lngWW As Long</p><p>  If LstApp.ListIndex < 0 Then Beep: Exit Sub</p><p>  hwnd = LstAp

48、p.ItemData(LstApp.ListIndex)</p><p>  '取得窗口的結(jié)構(gòu)信息</p><p>  lngWW = GetWindowLong(hwnd, GWL_STYLE)</p><p>  If lngWW And WS_MINIMIZE Then</p><p><b>  '控制窗口的

49、可見(jiàn)性</b></p><p>  X = ShowWindow(hwnd, SW_RESTORE)</p><p><b>  End If</b></p><p>  '指定一個(gè)窗口新的位置 '第2個(gè)參數(shù):將窗口置于Z序列的頂部.</p><p>  X = SetWindowPos(hw

50、nd, HWND_TOP, 0, 0, 0, 0, _</p><p>  SWP_NOMOVE Or SWP_NOSIZE Or SWP_SHOWWINDOW)</p><p>  End Sub '保持當(dāng)前位置或保持當(dāng)前大小或顯示窗口</p><p>  '彈出"新建任務(wù)"窗</p><p>  Pr

51、ivate Sub Command1_Click()</p><p>  frmnew.Show vbModal</p><p><b>  End Sub</b></p><p><b>  '結(jié)束應(yīng)用程序</b></p><p>  '還有就是在如果列表中沒(méi)有活動(dòng)程序,點(diǎn)擊&qu

52、ot;結(jié)束程序"會(huì)退出本身</p><p>  Private Sub Command3_Click()</p><p>  On Error Resume Next</p><p>  'If LstApp.ListCount = 0 Then</p><p>  '應(yīng)用程序的類(lèi)名,和程序的標(biāo)題</p>

53、<p>  Dim lpclassname As String, lpcaption As String</p><p><b>  '程序的句柄號(hào)</b></p><p>  Dim Handle As Long</p><p>  Dim Retval As Long</p><p>  

54、9;先是打開(kāi)要關(guān)閉的程序,其它就是將該程序顯示成當(dāng)前程序</p><p>  Shell LstApp.Text, 1</p><p>  lpclassname = LstApp.Text</p><p>  lpcaption = LstApp.Text</p><p><b>  '獲得程序的句柄號(hào)</b>

55、</p><p>  Handle = FindWindow(vbNullString, lpcaption)</p><p>  '用函數(shù)關(guān)閉應(yīng)用程序</p><p>  PostMessage Handle, WM_Close, 0&, 0&</p><p>  '所了和列表控件一至,在這里刪除列表中的該進(jìn)

56、程名</p><p>  LstApp.RemoveItem LstApp.ListIndex</p><p>  LstApp.refresh</p><p><b>  '刷新</b></p><p>  FindAllApps</p><p><b>  End Sub&l

57、t;/b></p><p>  '結(jié)束指定進(jìn)程功能代碼實(shí)現(xiàn)</p><p>  Private Sub Command4_Click()</p><p>  On Error Resume Next</p><p>  Dim i As Long, hand As Long, id As Long</p><

58、p>  If MsgBox("確定要結(jié)束進(jìn)程 " & List1.SelectedItem.Text & " 嗎?", vbExclamation + vbOKCancel) = vbCancel Then Exit Sub</p><p>  id = CLng(List1.SelectedItem.SubItems(1))</p>&

59、lt;p>  If id <> 0 Then</p><p><b>  EndPro id</b></p><p><b>  End If</b></p><p>  ListProcess</p><p><b>  End Sub</b></p&

60、gt;<p>  Private Sub Command5_Click()</p><p>  Dim AboutRet As Long</p><p>  AboutRet = ExitWindowsEx(EWX_LOGOFF, 0)</p><p><b>  End Sub</b></p><p>&

61、lt;b>  '注銷(xiāo)用戶功能實(shí)現(xiàn)</b></p><p>  Private Sub Command6_Click()</p><p>  Dim AboutRet As Long</p><p>  AboutRet = ExitWindowsEx(EWX_LOGOFF, 0)</p><p><b> 

62、 End Sub</b></p><p><b>  '切換至功能實(shí)現(xiàn)</b></p><p>  Private Sub cutoverto_Click()</p><p>  cmdSwitch_Click</p><p>  Me.WindowState = 1</p><p

63、><b>  End Sub</b></p><p><b>  '改變進(jìn)程顯示方式</b></p><p>  Private Sub Detailed_Click()</p><p>  List1.View = lvwReport</p><p><b>  End S

64、ub</b></p><p>  '結(jié)束應(yīng)用程序功能實(shí)現(xiàn)</p><p>  Private Sub endprograme_Click()</p><p>  Command3_Click</p><p><b>  End Sub</b></p><p><b>

65、  '關(guān)機(jī)功能實(shí)現(xiàn)</b></p><p>  Private Sub Exit_Click()</p><p>  frmclose.Show vbModal</p><p><b>  End Sub</b></p><p><b>  'CPU效率監(jiān)視</b><

66、;/p><p>  CpuPicture(0).ScaleMode = vbPixels</p><p>  CpuPicture(1).ScaleMode = vbPixels</p><p>  Set QueryObject = New CCpuwatch</p><p><b>  '對(duì)象初始化</b><

67、;/p><p>  QueryObject.Initialize</p><p><b>  '打開(kāi)時(shí)間控件</b></p><p>  tmrRefresh.Enabled = True</p><p><b>  '調(diào)用刷新過(guò)程</b></p><p>  t

68、mrRefresh_Timer</p><p>  '*****************************************</p><p><b>  '獲得所有系統(tǒng)進(jìn)程</b></p><p>  ListProcess</p><p><b>  '窗體總在前</

69、b></p><p>  SetTop Me, front.Checked</p><p>  '***************************************************</p><p>  '獲得系統(tǒng)的當(dāng)前用戶</p><p>  cnt& = 199</p><

70、;p>  s$ = String$(200, 0)</p><p>  dl& = GetUserName(s$, cnt)</p><p>  Set item = ListView3.ListItems.Add(, , s$, , 2)</p><p>  item.SubItems(2) = "正在運(yùn)行..."</p&g

71、t;<p>  item.SubItems(1) = WorkstationID</p><p><b>  '設(shè)置系統(tǒng)托盤(pán)</b></p><p>  If WindowState = vbMinimized Then</p><p>  LastState = vbNormal</p><p>

72、<b>  Else</b></p><p>  LastState = WindowState</p><p><b>  End If</b></p><p>  AddToTray Me, Tray</p><p><b>  End Sub</b></p>

73、<p>  Private Sub Form_Resize()</p><p>  Select Case WindowState</p><p>  Case vbMinimized</p><p>  Me.Visible = False</p><p>  Case vbMaximized</p><p&

74、gt;  Me.Visible = True</p><p>  End Select</p><p>  If WindowState <> vbMinimized Then</p><p>  LastState = WindowState</p><p>  Me.Visible = True</p><

75、p><b>  End If</b></p><p><b>  End Sub</b></p><p>  Private Sub Form_Unload(Cancel As Integer)</p><p>  RemoveFromTray '關(guān)閉托盤(pán)</p><p>  tm

76、rRefresh.Enabled = False</p><p><b>  Unload Me</b></p><p><b>  End Sub</b></p><p>  Private Sub front_Click()</p><p>  front.Checked = Not front

77、.Checked</p><p>  SetTop Me, front.Checked</p><p><b>  End Sub</b></p><p>  Private Sub jsjc_Click()</p><p>  Command4_Click</p><p><b>  

78、End Sub</b></p><p>  Private Sub List1_ColumnClick(ByVal ColumnHeader As MSComctlLib.ColumnHeader)</p><p>  On Error Resume Next</p><p>  With List1</p><p>  '

79、;設(shè)置 Sorted 為 True 以將列表排序。</p><p>  If (ColumnHeader.Index - 1) = .SortKey Then</p><p>  .SortOrder = (.SortOrder + 1) Mod 2</p><p>  .Sorted = True</p><p><b>  El

80、se</b></p><p>  .Sorted = False</p><p>  .SortOrder = 0</p><p>  .SortKey = ColumnHeader.Index - 1</p><p>  .Sorted = True</p><p><b>  End If&l

81、t;/b></p><p><b>  End With</b></p><p><b>  End Sub</b></p><p>  '右擊菜單;,,并初使化進(jìn)程的優(yōu)先級(jí)別</p><p>  Private Sub List1_MouseDown(Button As Intege

82、r, Shift As Integer, X As Single, y As Single)</p><p>  On Error Resume Next</p><p>  Dim j As Long, i As Long</p><p>  If Button = 2 Then</p><p>  If List1.HitTest(X,

83、y) Is Nothing Then Exit Sub</p><p>  j = List1.HitTest(X, y).Index</p><p>  List1.ListItems(j).Selected = True</p><p>  For i = 0 To 5</p><p>  mnuSetProClassSub(i).Che

84、cked = False</p><p><b>  Next</b></p><p>  Select Case List1.SelectedItem.SubItems(2)</p><p>  Case "實(shí)時(shí)": mnuSetProClassSub(0).Checked = True</p><p&

85、gt;  Case "高": mnuSetProClassSub(1).Checked = True</p><p>  Case "較高": mnuSetProClassSub(2).Checked = True</p><p>  Case "標(biāo)準(zhǔn)": mnuSetProClassSub(3).Checked = True&l

86、t;/p><p>  Case "較低": mnuSetProClassSub(4).Checked = True</p><p>  Case "低": mnuSetProClassSub(5).Checked = True</p><p>  End Select</p><p>  PopupMenu

87、 you</p><p><b>  End If</b></p><p><b>  End Sub</b></p><p>  Private Sub log_Click()</p><p>  frmclose.Show vbModal</p><p><b>

88、;  End Sub</b></p><p>  '雙擊切換到另一個(gè)程序</p><p>  Sub lstApp_DblClick()</p><p>  cmdSwitch.Value = True</p><p><b>  End Sub</b></p><p><

89、;b>  '任務(wù)窗</b></p><p>  Function TaskWindow(hwCurr As Long) As Long</p><p>  Dim lngStyle As Long</p><p>  '調(diào)用函數(shù)得到指定窗口的信息'第一個(gè)參數(shù)是指定窗口的句柄,第二個(gè)是窗口的樣式</p><

90、p>  lngStyle = GetWindowLong(hwCurr, GWL_STYLE)</p><p>  If (lngStyle And IsTask) = IsTask Then TaskWindow = True</p><p>  End Function</p><p><b>  '設(shè)置進(jìn)程優(yōu)先級(jí)</b>&l

91、t;/p><p>  Public Function SetProClass(ByVal PID As Long, ByVal ClassID As Long)</p><p>  On Error Resume Next</p><p>  Dim hwd As Long</p><p>  '在這里得到一個(gè)句柄</p>

92、<p>  hwd = OpenProcess(PROCESS_SET_INFORMATION, 0, PID)</p><p>  '調(diào)用這個(gè)函數(shù)設(shè)置進(jìn)程的優(yōu)先級(jí)</p><p>  SetProClass = SetPriorityClass(hwd, ClassID)</p><p>  End Function</p><

93、;p><b>  '右鍵菜單</b></p><p>  Private Sub LstApp_MouseDown(Button As Integer, Shift As Integer, X As Single, y As Single)</p><p>  If Button = 2 Then</p><p>  PopupM

94、enu Application</p><p><b>  End If</b></p><p><b>  End Sub</b></p><p>  '在這里設(shè)置進(jìn)程優(yōu)先級(jí)</p><p>  Private Sub mnuSetProClassSub_Click(Index As In

95、teger)</p><p>  On Error Resume Next</p><p>  Dim PID As Long, rtn As Long</p><p>  PID = CLng(List1.SelectedItem.SubItems(1)) '得到進(jìn)程PID</p><p>  If mnuSetProClassS

96、ub(Index).Checked = True Then Exit Sub</p><p>  Select Case Index</p><p>  Case 1: rtn = SetProClass(PID, HIGH_PRIORITY_CLASS) '高</p><p>  Case 2: rtn = SetProClass(PID, 32

97、768) '較高</p><p>  Case 3: rtn = SetProClass(PID, NORMAL_PRIORITY_CLASS) '標(biāo)準(zhǔn)</p><p>  Case 4: rtn = SetProClass(PID, 16384) '較低</p><

98、;p>  Case 5: rtn = SetProClass(PID, IDLE_PRIORITY_CLASS) '低</p><p>  End Select</p><p>  If rtn = 0 Then MsgBox "無(wú)法為進(jìn)程 " & List1.SelectedItem.Text & " 設(shè)置優(yōu)先級(jí)。&q

99、uot;, vbCritical</p><p><b>  End Sub</b></p><p>  '彈出"新建任務(wù)"窗</p><p>  Private Sub newfile_Click()</p><p>  frmnew.Show vbModal</p><

100、p><b>  End Sub</b></p><p>  Private Sub plaseago_Click()</p><p>  cmdSwitch_Click</p><p><b>  End Sub</b></p><p>  Private Sub refresh_Click(

101、)</p><p>  frmclose.Show vbModal</p><p><b>  End Sub</b></p><p><b>  '刷新</b></p><p>  Private Sub refresh1_Click()</p><p>  Fin

102、dAllApps</p><p><b>  End Sub</b></p><p>  Private Sub showago_Click()</p><p>  showago.Checked = Not showago.Checked</p><p>  SetTop Me, showago.Checked<

103、/p><p><b>  End Sub</b></p><p>  Private Sub small_Click()</p><p>  List1.View = Index + 2</p><p>  List1.Sorted = True</p><p><b>  End Sub&

104、lt;/b></p><p>  Private Sub SSTab1_DblClick()</p><p><b>  End Sub</b></p><p>  Private Sub Timer3_Timer()</p><p>  Dim X As Long</p><p>  Ca

105、ll GlobalMemoryStatus(minfo)</p><p><b>  '總的內(nèi)存量</b></p><p>  X = -minfo.dwTotalPhys / 1024</p><p>  Label2(0).Caption = Str$(Int(X))</p><p><b>  &

106、#39;可用的內(nèi)存量</b></p><p>  X = minfo.dwAvailPhys / 1024</p><p>  Label2(1).Caption = Str$(Int(X))</p><p><b>  '系統(tǒng)緩存</b></p><p>  Label2(2).Caption =

107、-(Val(Label2(0)) - Val(Label2(1)) - 500)</p><p><b>  '虛擬內(nèi)存總數(shù)</b></p><p>  X = minfo.dwTotalVirtual / 1024</p><p>  Label7(0).Caption = Str$(Int(X / 1024)) & &quo

108、t; M"</p><p><b>  '可用虛擬內(nèi)存</b></p><p>  X = minfo.dwAvailVirtual / 1024</p><p>  Label7(1).Caption = Str$(Int(X / 1024)) & " M"</p><p>

109、;<b>  End Sub</b></p><p>  Private Sub Timer4_Timer()</p><p>  Line14.X2 = Line14.X2 - 20</p><p>  Line14.X1 = Line14.X1 - 20</p><p>  If Line14.X1 = 0 Then

110、</p><p>  Timer4.Enabled = False</p><p><b>  Else</b></p><p>  Timer4.Enabled = True</p><p><b>  End If</b></p><p><b>  End S

111、ub</b></p><p>  Private Sub Timer6_Timer()</p><p>  FindAllApps</p><p><b>  End Sub</b></p><p><b>  'CPU效率監(jiān)視</b></p><p> 

112、 Private Sub tmrRefresh_Timer()</p><p>  Dim Ret As Integer</p><p>  Dim cnt As Integer</p><p>  Dim i As Integer</p><p><b>  '返回CPU狀態(tài)</b></p>&l

113、t;p>  Ret = QueryObject.Query</p><p>  cnt = Int(Ret / 10 + 1)</p><p>  CpuPicture(0).Cls '清除窗口中的內(nèi)容</p><p>  If Ret <> -1 Then</p><p>  For i = 0 To cnt

114、- 1</p><p>  '用PIC控件的LINE方法在PIC上畫(huà)圖,用以顯示CPU的占用率</p><p>  CpuPicture(0).Line (2, 70 - (5 + i * 6))-(79, 70 - (5 + i * 6 + 2)), &HFF00&, BF</p><p><b>  Next i</b&g

115、t;</p><p>  ShiftPoints</p><p>  GraphPoints(UBound(GraphPoints)) = Ret</p><p>  CpuPicture(1).Cls</p><p>  For cnt = LBound(GraphPoints) To UBound(GraphPoints) - 1<

116、/p><p>  CpuPicture(1).Line (cnt, 80 - GraphPoints(cnt))-(cnt + 1, 80 - GraphPoints(cnt + 1)), &HFF00&</p><p><b>  Next cnt</b></p><p>  CpuLabel.Caption = CStr(Ret

117、) + "%"</p><p>  Label4.Caption = "CPU 使用:" &CStr(Ret) + "%"</p><p>  '托盤(pán)顯示CPU使用率</p><p>  SetTrayTip "CPU 使用:" &CStr(Ret) + &quo

118、t; %"</p><p><b>  End If</b></p><p><b>  End Sub</b></p><p><b>  'CPU效率監(jiān)視</b></p><p>  Sub ShiftPoints()</p><p&g

119、t;  Dim cnt As Integer</p><p>  For cnt = LBound(GraphPoints) To UBound(GraphPoints) - 1</p><p>  GraphPoints(cnt) = GraphPoints(cnt + 1)</p><p><b>  Next cnt</b></p&

120、gt;<p><b>  End Sub</b></p><p>  '判斷item是否存在</p><p>  Public Function HaveItem(ByVal itemID As Long) As Long</p><p>  On Error GoTo zbb</p><p>  

121、HaveItem = List1.ListItems("ID:" & CStr(itemID)).Index</p><p>  Exit Function</p><p><b>  zbb:</b></p><p>  HaveItem = 0</p><p>  End Function

122、</p><p><b>  '結(jié)束一個(gè)進(jìn)程</b></p><p>  Public Sub EndPro(ByVal PID As Long)</p><p>  On Error Resume Next</p><p>  Dim lngHwndProcess As Long</p><

123、p>  Dim hand As Long</p><p>  Dim exitCode As Long</p><p>  '打開(kāi)要結(jié)束的進(jìn)程,把該進(jìn)程的句柄賦給變量</p><p>  hand = OpenProcess(PROCESS_TERMINATE, True, PID)</p><p><b>  

124、9;結(jié)束進(jìn)程</b></p><p>  TerminateProcess hand, exitCode</p><p>  '關(guān)閉進(jìn)程的內(nèi)核對(duì)象......(除非對(duì)內(nèi)核對(duì)象的所有引用都已關(guān)閉,否則該對(duì)象不會(huì)實(shí)際刪除)</p><p>  CloseHandle hand</p><p><b>  End Su

125、b</b></p><p>  Private Sub Timer2_Timer()</p><p>  CheckProcess</p><p><b>  End Sub</b></p><p>  Private Sub Timer1_Timer()</p><p>  List

126、Process</p><p><b>  End Sub</b></p><p>  '將正在運(yùn)行的應(yīng)用程序加到列表控件中</p><p>  Sub FindAllApps()</p><p>  Dim hwCurr As Long</p><p>  Dim intLen As L

127、ong</p><p>  Dim strTitle As String</p><p>  Dim item As ListItem</p><p><b>  '先清空</b></p><p>  LstApp.Clear</p><p>  '獲取一個(gè)窗口的句柄

128、'為一個(gè)源子窗口尋找第一個(gè)兄弟(同級(jí))窗口,或?qū)ふ业谝粋€(gè)頂級(jí)窗口</p><p>  hwCurr = GetWindow(Me.hwnd, GW_HWNDFIRST)</p><p>  Do While hwCurr</p><p>  If hwCurr <> Me.hwnd And TaskWindow(hwCurr) Then</

129、p><p>  '調(diào)查窗口標(biāo)題文字或控件內(nèi)容的長(zhǎng)短</p><p>  intLen = GetWindowTextLength(hwCurr) + 1</p><p>  strTitle = Space$(intLen)</p><p>  '取得窗體的標(biāo)題(caption)文字</p><p>  i

130、ntLen = GetWindowText(hwCurr, strTitle, intLen)</p><p>  If intLen > 0 Then</p><p>  LstApp.AddItem strTitle</p><p>  'Set item = LstApp.ListItems.Add(, , strTitle, 3)</p&

131、gt;<p>  LstApp.ItemData(LstApp.NewIndex) = hwCurr</p><p><b>  End If</b></p><p><b>  End If</b></p><p>  '獲取下一個(gè)窗口的句柄</p><p>  hwCurr

132、 = GetWindow(hwCurr, GW_HWNDNEXT)</p><p><b>  Loop</b></p><p><b>  End Sub</b></p><p>  Public Function CheckPath(ByVal PathStr As String) As String</p>

133、;<p>  On Error Resume Next</p><p>  '返回一個(gè)字符串,該字符串中指定的子字符串已被替換成另一子字符串,并且替換發(fā)生的次數(shù)也是指定的。</p><p>  PathStr = Replace(PathStr, "\??\", "")</p><p>  If UCas

134、e(Left$(PathStr, 12)) = "\SYSTEMROOT\" Then PathStr = GetWinDir & Mid$(PathStr, 12)</p><p>  CheckPath = PathStr</p><p>  End Function</p><p><b>  新建一個(gè)進(jìn)程的命令</

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論