資源描述:
《windows下編寫一個控制臺應(yīng)用程序》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫。
1、實驗概述【實驗?zāi)康募耙蟆?.在windows下編寫一個控制臺應(yīng)用程序,命名為an_ch2_lbo這個程序不斷地輸出如下行:Thoseoutputcomefromchild,[系統(tǒng)時間]另外寫一個控制臺應(yīng)用程序,命名為an_ch2_lao這個程序創(chuàng)建一個子進程,執(zhí)行an_ch2lbo這個程序不斷地輸出如下行:Thoseoutputcomefromchild,[系統(tǒng)時間]觀察程序運行的結(jié)果,并對你看到的現(xiàn)象進行解釋。你如何修改程序使得兩個進程的輸出出現(xiàn)在兩個不同的控制臺窗口上?2.在windows環(huán)境下編寫一
2、個控制臺應(yīng)用程序,輸出系統(tǒng)中正在運行的進程的信息,包括進程號、進程所運行的程序、進程的啟動時間、在核心態(tài)下消耗的時間以及在用戶態(tài)下消耗的時間。3.在windows環(huán)境下編寫一個控制臺應(yīng)用程序,程序中有一個共享的整型變量shared_var,初始值為0;創(chuàng)建一個線程并使其立即與主線程并發(fā)執(zhí)行。新創(chuàng)建的線程與主蠶程均不斷地循環(huán),并輸出shared_var的值。主線程在循環(huán)中不斷地對shared_var進行加1操作,即每次循環(huán)sharedvar被加1;而新創(chuàng)建的線程則不斷地對sharedvar進行減1操作,即每次
3、循環(huán)sharedvar被減1。觀察程序運行的結(jié)果,并對你看到的現(xiàn)象進行解釋?!緦嶒灜h(huán)境】硬件:CPU:IntelPentiumMprocessor1.60GHZ軟件:windowsxp,vc6.0實驗內(nèi)容【實驗過程】(實驗步驟、記錄、數(shù)據(jù)、分析)1主要代碼:程序an_ch2_lb#include”windows.h”#includevoidmain(intargc,char*argv[]){STARTUPINFOsi={sizeof(si)};PROCESSINFORMATIONpi;Cre
4、ateProcess(Hf:\mydocumentsWstudyWoperationsystems\ar_ch_1b\Debug\ar_ch_1b.exe",L漫執(zhí)行的子程序路徑NULL,/存程序的命令行參藪NULL,//NULL,//FALSE,//0,NULL,//NULL,//SYSTEMTIMEsys;for(inti=0;iv500;i++){GetSystemTime(&sys)://得到當前的系統(tǒng)時間printf(”Thoseoutputcomefromnode,currenttime
5、is%4d/%02d/%02d%02d:%02d:%02d.%03dM,sys.wYear,sys.wMonth,sys.wDay,sys.wHour,sys.wMinute,sys.wSecond,sys.wMMiseconds,sys.wDayOfWeek);程序an_ch2_lbinclude"windows.hH#includevoidmain(intargc,char*argv[]){SYSTEMTIMEsys;for(inti=0;iv500;i++){GetSystemTi
6、me(&sys);printf(HThoseoutputcomefromchild,currenttimeis%4d/%02d/%02d%02d:%02d:%02d.%03dM,sys.wYear,sys.wMonth,sys.wDay,sys.wHour,sys.wMinute,sys.wSecond,sys.wMilliseconds);運行結(jié)果:Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefro
7、mnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2
8、008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutputcomefromnode,currenttimeis2008/10/2807:45:39.703Thoseoutpu