程序分為 操作系統(tǒng)和應(yīng)用程序.
新會網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)自2013年起到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
應(yīng)用程序的運行建立在操作系統(tǒng)基礎(chǔ)上,所以可以說操作系統(tǒng)是底層的程序, 而相對的,應(yīng)用程序就算高層的程序了.
所謂的“底層編成”就是指一些核心的編成(抽象說就是離操作系統(tǒng)近).
"windows底層編程"就是基于window操作系統(tǒng)的核心的編成.
1、剪切板相當于一個中間儲存柜,
2、需復(fù)制的內(nèi)容(文字、圖片、多媒體、文件、文件夾等)在選擇“復(fù)制”功能后,數(shù)據(jù)就暫時保存在這里,
3、在進行下一步“粘貼”操作時,操作系統(tǒng)就將保存在剪切板內(nèi)的數(shù)據(jù)進行復(fù)制并保存到指定的位置。這就是復(fù)制粘貼的原理。
4、在下一次執(zhí)行“復(fù)制”功能后,上一次保存在剪切板內(nèi)的數(shù)據(jù)就被新復(fù)制的內(nèi)容所取代,如果沒有執(zhí)行過“復(fù)制”功能,則第一次復(fù)制的內(nèi)容在關(guān)機前都一直存在剪切板里,關(guān)機后就沒有了,因為剪切板只是臨時性的。
1.語言C/C++(參考書籍:C/C++ Primer ,C和指針,數(shù)據(jù)結(jié)構(gòu)C語言描述)),匯編(王爽的匯編語言,作為入門,參考Intel手冊,之后參考看雪的加密與解密,了解PE文件的格式,加殼脫殼和病毒感染的手法,如果是開發(fā)的話,只需要了解即可,能用反匯編調(diào)試工具去做簡單的CrackMe即可),這個階段大約是大一大二的時間,除去老師上課教的C語言基礎(chǔ),80x86匯編語言以為,很多知識都是自己去擴展。
2.windows api(win32sdk) 參考書籍(《Windows程序設(shè)計》,《Windows核心編程》,MFC之類的需要使用的時候在參考即可,不必花費太多精力,主要是去了解程序的消息機制,事件等等,應(yīng)該把主要的精力比如線程注入,Ring3的各種HOOK等。這個階段是大二下學期的時間,說實話,我這個方面看的太少了,花了好多時間在一些沒有意義的事情上,導(dǎo)致到大三的時候參加信息安全比賽做驅(qū)動的時候經(jīng)驗嚴重不足,所以基礎(chǔ)太重要了)
3.然后就是winows驅(qū)動內(nèi)核的開發(fā)(參考書籍,寒江獨釣,張帆的Windows驅(qū)動開發(fā)技術(shù)詳解,WDK上的各種示例代碼) 熟悉各種過濾驅(qū)動框架(文件過濾驅(qū)動,文件微過濾驅(qū)動,tdi,ndis協(xié)議,ndis中間層,ndis小端口等等)。
然后就是各種系統(tǒng)底層的原理,進程創(chuàng)建的流程,文件創(chuàng)建的流程,進程間通信的過程,用各種調(diào)試,反匯編工具(od,ida,windbg)去跟蹤分析,可以寫一些Rootkit/Anti-Rootkit工具,比如對于進程隱藏和保護,有SSDT HOOK OpenProcess,摘除進程鏈表等等,這樣有助于對系統(tǒng)底層機制的理解
4.后期就是經(jīng)驗和內(nèi)功了,什么《深入解析Windows操作系統(tǒng)》,《TCP/IP》卷123,《Windows內(nèi)核原理與實現(xiàn)》等等,說白了,個人認為,底層開發(fā)對于調(diào)試的功力要求很高,能從藍屏的dump文件出有用的信息
應(yīng)該不是,Windows就是Windows系統(tǒng),Linux底層不能說是Unix,Linux是Unix的升級改造,而Android底層是Linux
不是,Windows系統(tǒng)的內(nèi)核是微軟自己獨立開發(fā)的,現(xiàn)在的Windows系統(tǒng)的內(nèi)核叫做NT內(nèi)核,而linux系統(tǒng)的內(nèi)核則是GNU開放源代碼的,兩者并不一樣。