版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、系統(tǒng)核心編程實(shí)驗(yàn) (WIN+C) 第三章 內(nèi)核對象,,知識(shí)要點(diǎn),3.1 CreateIcon3.2 CreateFile3.3 CloseHandle,3.1 CreateIcon,LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)switch (message)case WM_PAINT:hdc = BeginPa
2、int(hWnd, &ps);// TODO: 在此添加任意繪圖代碼...EndPaint(hWnd, &ps);break;,3.1 CreateIcon,HICON hIcon3; // icon handle hIcon3 = CreateIcon( hInst, // application instance 32, // icon w
3、idth 32, // icon height 1, // number of XOR planes 1, // number of bits per pixel ANDmaskIcon, // AND bitmask XORmaskIcon); // XOR
4、 bitmaskDrawIcon(hdc, 10, 20, hIcon3);,3.1 CreateIcon,在創(chuàng)建圖標(biāo)時(shí),CreateIcon()函數(shù)使用下列的原理表來AND和XOR位掩碼:AND位掩碼 XOR位掩碼 顯示 -----------------------------------------0 0 黑色 0 1 白色 1 0 屏幕 1 1 屏幕的反色,,// Yang icon AND bitmask
5、BYTE ANDmaskIcon[] = {0xFF, 0xFF, 0xFF, 0xFF, // line 1 0xFF, 0xFF, 0xC3, 0xFF, // line 2 0xFF, 0xFF, 0x00, 0xFF, // line 3 0xFF, 0xFE, 0x00, 0x7F, // line 4 0xFF, 0xFC, 0x00, 0x1F, // line 5
6、0xFF, 0xF8, 0x00, 0x0F, // line 6 0xFF, 0xF8, 0x00, 0x0F, // line 7 0xFF, 0xF0, 0x00, 0x07, // line 8 0xFF, 0xF0, 0x00, 0x03, // line 9 0xFF, 0xE0, 0x00, 0x03, // line 10 0xFF, 0xE0, 0x00, 0
7、x01, // line 11 0xFF, 0xE0, 0x00, 0x01, // line 12 0xFF, 0xF0, 0x00, 0x01, // line 13 0xFF, 0xF0, 0x00, 0x00, // line 14 0xFF, 0xF8, 0x00, 0x00, // line 15 0xFF, 0xFC, 0x00, 0x00, // line 16
8、0xFF, 0xFF, 0x00, 0x00, // line 17 0xFF, 0xFF, 0x80, 0x00, // line 18 0xFF, 0xFF, 0xE0, 0x00, // line 19 0xFF, 0xFF, 0xE0, 0x01, // line 20 0xFF, 0xFF, 0xF0, 0x01, // line 21 0xFF, 0xFF, 0xF0, 0
9、x01, // line 22 0xFF, 0xFF, 0xF0, 0x03, // line 23 0xFF, 0xFF, 0xE0, 0x03, // line 24 0xFF, 0xFF, 0xE0, 0x07, // line 25 0xFF, 0xFF, 0xC0, 0x0F, // line 26 0xFF, 0xFF, 0xC0, 0x0F, // line 27
10、0xFF, 0xFF, 0x80, 0x1F, // line 28 0xFF, 0xFF, 0x00, 0x7F, // line 29 0xFF, 0xFC, 0x00, 0xFF, // line 30 0xFF, 0xF8, 0x03, 0xFF, // line 31 0xFF, 0xFC, 0x3F, 0xFF}; // line 32,,// Yang icon XOR bitma
11、sk BYTE XORmaskIcon[] = {0x00, 0x00, 0x00, 0x00, // line 1 0x00, 0x00, 0x00, 0x00, // line 2 0x00, 0x00, 0x00, 0x00, // line 3 0x00, 0x00, 0x00, 0x00, // line 4 0x00, 0x00, 0x00, 0x00,
12、// line 5 0x00, 0x00, 0x00, 0x00, // line 6 0x00, 0x00, 0x00, 0x00, // line 7 0x00, 0x00, 0x38, 0x00, // line 8 0x00, 0x00, 0x7C, 0x00, // line 9 0x00, 0x00, 0x7C, 0x00, // line 10 0x0
13、0, 0x00, 0x7C, 0x00, // line 11 0x00, 0x00, 0x38, 0x00, // line 12 0x00, 0x00, 0x00, 0x00, // line 13 0x00, 0x00, 0x00, 0x00, // line 14 0x00, 0x00, 0x00, 0x00, // line 15 0x00, 0x00, 0x00,
14、0x00, // line 16 0x00, 0x00, 0x00, 0x00, // line 17 0x00, 0x00, 0x00, 0x00, // line 18 0x00, 0x00, 0x00, 0x00, // line 19 0x00, 0x00, 0x00, 0x00, // line 20 0x00, 0x00, 0x00, 0x00, // line 2
15、1 0x00, 0x00, 0x00, 0x00, // line 22 0x00, 0x00, 0x00, 0x00, // line 23 0x00, 0x00, 0x00, 0x00, // line 24 0x00, 0x00, 0x00, 0x00, // line 25 0x00, 0x00, 0x00, 0x00, // line 26 0x00, 0
16、x00, 0x00, 0x00, // line 27 0x00, 0x00, 0x00, 0x00, // line 28 0x00, 0x00, 0x00, 0x00, // line 29 0x00, 0x00, 0x00, 0x00, // line 30 0x00, 0x00, 0x00, 0x00, // line 31 0x00, 0x00, 0x00, 0x00
17、}; // line 32,3.1 CreateIcon,,3.2 CreateFile,HANDLE CreateFile(LPCTSTR lpFileName, //指向文件名的指針DWORD dwDesiredAccess, //訪問模式(寫/讀)DWORD dwShareMode, //共享模式LPSECURITY_ATTRIBUTES lpSecurityAttributes, //指向安全屬性的指針DWORD dw
18、CreationDisposition, //如何創(chuàng)建DWORD dwFlagsAndAttributes, //文件屬性HANDLE hTemplateFile //用于復(fù)制文件句柄);,3.2 CreateFile,參數(shù)列表 lpFileName String 要打開的文件的名字 dwDesiredAccess Long 如果為 GENERIC_READ 表示允許對設(shè)備進(jìn)行讀訪問;如果為 GENERIC_WRITE 表示允
19、許對設(shè)備進(jìn)行寫訪問(可組合使用);如果為零,表示只允許獲取與一個(gè)設(shè)備有關(guān)的信息 dwShareMode Long, 零表示不共享; FILE_SHARE_READ 和/或 FILE_SHARE_WRITE 表示允許對文件進(jìn)行共享訪問lpSecurityAttributes SECURITY_ATTRIBUTES, 指向一個(gè)SECURITY_ATTRIBUTES結(jié)構(gòu)的指針,定義了文件的安全特性(如果操作系統(tǒng)支持的話),3.2 Crea
20、teFile,參數(shù)列表dwCreationDisposition Long,下述常數(shù)之一:CREATE_NEW 創(chuàng)建文件;如文件存在則會(huì)出錯(cuò) CREATE_ALWAYS 創(chuàng)建文件,會(huì)改寫前一個(gè)文件OPEN_EXISTING 文件必須已經(jīng)存在。由設(shè)備提出要求OPEN_ALWAYS 如文件不存在則創(chuàng)建它 TRUNCATE_EXISTING 講現(xiàn)有文件縮短為零長度,3.2 CreateFile,dwFlagsAndAttribu
21、tes Long, 一個(gè)或多個(gè)下述常數(shù) FILE_ATTRIBUTE_ARCHIVE 標(biāo)記歸檔屬性 FILE_ATTRIBUTE_COMPRESSED 將文件標(biāo)記為已壓縮,或者標(biāo)記為文件在目錄中的默認(rèn)壓縮方式 FILE_ATTRIBUTE_NORMAL 默認(rèn)屬性 FILE_ATTRIBUTE_HIDDEN 隱藏文件或目錄 FILE_ATTRIBUTE_READONLY 文件為只讀 FILE_ATTRIBUTE_SYSTEM
22、文件為系統(tǒng)文件 FILE_FLAG_WRITE_THROUGH 操作系統(tǒng)不得推遲對文件的寫操作 FILE_FLAG_OVERLAPPED 允許對文件進(jìn)行重疊操作 FILE_FLAG_NO_BUFFERING 禁止對文件進(jìn)行緩沖處理。文件只能寫入磁盤卷的扇區(qū)塊 FILE_FLAG_RANDOM_ACCESS 針對隨機(jī)訪問對文件緩沖進(jìn)行優(yōu)化 FILE_FLAG_SEQUENTIAL_SCAN 針對連續(xù)訪問對文件緩沖進(jìn)行優(yōu)化 FI
23、LE_FLAG_DELETE_ON_CLOSE 關(guān)閉了上一次打開的句柄后,將文件刪除。特別適合臨時(shí)文件,3.2 CreateFile,hTemplateFile Long, 如果不為零,則指定一個(gè)文件句柄。新文件將從這個(gè)文件中復(fù)制擴(kuò)展屬性。,3.2 CreateFile,int APIENTRY _tWinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPTSTR lp
24、CmdLine,int nCmdShow){ return 0;},3.2 CreateFile,HANDLE hFile = CreateFile(TEXT("E:\\Jeff.txt"),GENERIC_READ, FILE_SHARE_READ,NULL,OPEN_EXISTING, FILE_ATTRIBUTE_READONLY, NULL);if (hFile == INVALID
25、_HANDLE_VALUE) MessageBox(NULL, TEXT("error!"), TEXT("title"), MB_OK);else MessageBox(NULL, TEXT("Hello!"), TEXT("title"), MB_OK);,3.2 CreateFile,HANDLE hFile = CreateFile(TEXT(
26、"E:\\Jeff.txt"),GENERIC_READ, FILE_SHARE_READ,NULL,OPEN_ALWAYS, FILE_ATTRIBUTE_READONLY, NULL);if (hFile == INVALID_HANDLE_VALUE) MessageBox(NULL, TEXT("error!"), TEXT("title"), MB_OK);el
27、se MessageBox(NULL, TEXT("Hello!"), TEXT("title"), MB_OK);,3.2 CreateFile,CHAR *pBuffer;DWORD RSize;int fileSize = 0;int i;HANDLE hOpenFile = (HANDLE)CreateFile(L"E:\\a.text", GENERIC_R
28、EAD, FILE_SHARE_READ, NULL, OPEN_EXISTING, NULL, NULL);if (hOpenFile == INVALID_HANDLE_VALUE){ hOpenFile = NULL; MessageBoxA(NULL, "Can not open the file", "Playwav", MB_OK);}fileSi
29、ze = GetFileSize(hOpenFile, NULL);pBuffer = (CHAR *) malloc(fileSize);ReadFile(hOpenFile, pBuffer, fileSize, &RSize, NULL);//可將pBuffer顯示在某區(qū)域或?qū)懭肓硪粋€(gè)文件來檢查讀出是否正確 18. free(pBuffer);,3.3 CloseHandle,無論以什么方式創(chuàng)建內(nèi)核對象,都要調(diào)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 什么是內(nèi)核對象
- 系統(tǒng)創(chuàng)建一個(gè)線程內(nèi)核對象。
- 內(nèi)核中c++編程
- 基于內(nèi)核對象的動(dòng)態(tài)惡意代碼檢測.pdf
- 基于windows(2000-2003)內(nèi)核對象的rootkit檢測.pdf
- 基于內(nèi)核對象鏈接關(guān)系的內(nèi)存取證研究.pdf
- 基于內(nèi)核對象行為的惡意代碼檢測方法及其本體表示.pdf
- 標(biāo)準(zhǔn)C的面向?qū)ο缶幊棠芰U(kuò)展.pdf
- linux0.11內(nèi)核研究與內(nèi)核編程實(shí)踐
- 內(nèi)核編程筆記(一、內(nèi)核字符串處理)
- windows內(nèi)核安全編程實(shí)踐之路
- win32串口編程
- 考核周期和考核對象ppt課件
- 保前調(diào)研階段的法律審核對象
- 考核對象現(xiàn)實(shí)表現(xiàn)情況鑒定表
- 面向?qū)ο笈c圖形編程
-
評(píng)論
0/150
提交評(píng)論