超神當(dāng)然要一些超神的理由奕删,就是做出來神一樣的東西拄氯,讓人覺得不可思議渡蜻。
程序員的一些練手項(xiàng)目:
- 操作系統(tǒng)
- 編譯器
- 編輯器
- web服務(wù)器
- 數(shù)據(jù)庫
- 喜歡的游戲
- 瀏覽器
- 視頻播放器
- 自動(dòng)化執(zhí)行工具
- whatever满俗。
這些東西有的是很難的菩鲜,即使做出來一個(gè)簡單的示例也需要很多的精力腻菇。當(dāng)做出來很強(qiáng)大的東西胳螟,也有業(yè)界的標(biāo)準(zhǔn)進(jìn)行比較昔馋,足以讓你找到差距。這個(gè)列表幾乎一輩子也做不完糖耸,還有很多可以補(bǔ)充的秘遏,而且其中都是他人已竟之事,除非你可以干的更好嘉竟,要不就沒有實(shí)際的價(jià)值邦危,但是你學(xué)到的東西可以在其他地方使用。做經(jīng)典的項(xiàng)目練就強(qiáng)大的執(zhí)行力舍扰,在下一次實(shí)際項(xiàng)目中發(fā)力倦蚪。
突然有一天,我發(fā)現(xiàn)我的周圍全是神边苹,我知道我遇到了神一樣的對手陵且,我必須有一條超神之路员帮。
其實(shí)我想告訴你,你就是神嫌套。你必須有基本的知識雨饺,才能進(jìn)行。首先有一門程序語言護(hù)體燎含,再有幾門輔助,熟悉基本的數(shù)據(jù)結(jié)構(gòu)算法,閱讀相關(guān)書籍桩警,注意不要讀的太多,實(shí)際中體會(huì)書籍昌妹,而不只是讀一下就沒了捶枢。在遇到問題是去學(xué)習(xí),在完成任務(wù)后去總結(jié)飞崖。
最近出現(xiàn)的東西更多烂叔,分布式相關(guān)的,目前我還沒有掌握固歪。新出現(xiàn)的開發(fā)模式也很多蒜鸡,我踏上了一條漫漫長路。
文章的重點(diǎn)
說了這么多虛的牢裳,來點(diǎn)實(shí)在的吧逢防。就說操作系統(tǒng)提供的接口,有進(jìn)程管理蒲讯,內(nèi)存管理忘朝,文件管理等等。對于初學(xué)者判帮,肯定感覺亂七八糟的局嘁,這么多又記不住溉箕,更不知如何實(shí)現(xiàn)。
對于操作系統(tǒng)的功能悦昵,書上說抽象硬件肴茄,實(shí)在有點(diǎn)不容易理解。首先讓我們熟悉一下shell的用法吧旱捧,有命令執(zhí)行独郎,管道,重定向枚赡,甚至可以定義變量和函數(shù)氓癌,包括一定的腳本語言特性,shell可以看做是作為一種展示操作系統(tǒng)接口組合可能的實(shí)例(cat cd ps > | & $ #)贫橙,基本展示了系統(tǒng)的接口和組合的方法(xv6書上說的)贪婉。
進(jìn)程管理當(dāng)然很牛叉了,實(shí)現(xiàn)shell肯定需要fork卢肃,wait這樣的東西疲迂。里面牽扯的東西,我目前還不懂莫湘,不能細(xì)說尤蒿。文件管理和管道自不必多說,你肯定先要知道這些功能的存在幅垮,使用一下腰池。我慢慢研習(xí)后再吐槽。
在實(shí)現(xiàn)shell時(shí)忙芒,有命令行解析示弓,肯定會(huì)利用到詞法解析的功能(這個(gè)就是編譯原理中萬里長征的第一步),這里不再延伸了呵萨。shell是一個(gè)應(yīng)用程序奏属,對于傳入的命令調(diào)用系統(tǒng)內(nèi)核提供的接口。
sh代碼
if(fork1() == 0)
runcmd(parsecmd(buf));
wait();
其實(shí)操作系統(tǒng)更難以理解的是啟動(dòng)(有很多歷史規(guī)則)潮峦,首先制作一個(gè)鏡像磁盤需要很多知識和工具囱皿,在磁盤啟動(dòng)扇區(qū)里寫上執(zhí)行程序,只是一個(gè)啟動(dòng)加載程序跑杭,真正的程序在另一塊地方铆帽。就算制作好了,在真機(jī)上運(yùn)行還是很費(fèi)勁德谅,必須使用虛擬機(jī)爹橱。
程序一切執(zhí)行好了,把設(shè)備處理好了(此處省略了十萬八千個(gè)字),這個(gè)時(shí)候有一個(gè)初始化程序愧驱,pid是1慰技,一般情況會(huì)打開一個(gè)shell(exec sh)。
最重要的還沒有說组砚,對了吻商,肯定是匯編語言,現(xiàn)在會(huì)這個(gè)的人本就不多糟红,起碼我只會(huì)幾個(gè)指令艾帐。Ok ,let`s see a hello word example.
hello.asm
section .text
global _start ;must be declared for linker (ld)
_start: ;tells linker entry point
mov edx,len ;message length
mov ecx,msg ;message to write
call _print
call _sys_exit
_print:
mov ebx,1 ;file descriptor (stdout)
mov eax,4 ;system call number (sys_write)
int 0x80 ;call kernel
_sys_exit:
mov eax,1 ;system call number (sys_exit)
int 0x80 ;call kernel
section .data
msg db 'Hello, world!', 0xa ;string to be printed
len equ $ - msg ;length of the string
看看匯編語言如何轉(zhuǎn)換成可執(zhí)行程序。
run asm .sh
nasm -f elf hi.asm
ld -m elf_i386 -s -o hello hi.o
./hello
匯編語言的調(diào)用是先在某幾個(gè)寄存器填上值盆偿,或者內(nèi)存地址柒爸,然后進(jìn)行系統(tǒng)調(diào)用就可以(在上面的例子,eax 1代表退出事扭,eax 4 代表寫指令 也需要在ecx字符地址和 ecx 長度 和ebx 1代表輸出)捎稚。具體的網(wǎng)上有一些教程,也有一些參考手冊求橄。對比高級編程語言是f(x)今野,就簡單多了。
要寫啟動(dòng)程序罐农,肯定得理解啟動(dòng)過程条霜,內(nèi)存的分布(內(nèi)存竟然有洞),BIOS提供的指令涵亏,終于有了一點(diǎn)起色后就可以進(jìn)入c語言的世界了蛔外。
c語言的世界,又是很多人慘痛的記憶了溯乒,這里有你很多不能使用的東西,一些時(shí)候還是要借助匯編豹爹,當(dāng)然你需要明白那里需要什么(用那些指令)裆悄。
就說unix 6的源碼,近一萬行臂聋,似乎也不是很多嗎光稼,但是里面定義的變量很多,關(guān)系復(fù)雜孩等,沒有整體結(jié)構(gòu)的把屋艾君,就很難讀,關(guān)鍵是依賴很多其他知識肄方,例如要理解一段代碼可能需要幾頁輔助知識冰垄。
怎么樣,需要的基礎(chǔ)知識很多吧权她,是不是感覺要從入門到放棄了虹茶,當(dāng)然不想放棄對不對逝薪,找本書看看,看不懂換本看蝴罪,一遍不懂多看幾遍董济。
技術(shù)方便我就理解有這么多了,也許寫或者讀一系列的文章是不錯(cuò)的要门。團(tuán)隊(duì)合作方面的就關(guān)乎軟件工程了虏肾,需要更多的工具和方法論,就是經(jīng)驗(yàn)欢搜。
當(dāng)然這一切關(guān)乎思考封豪,程序員最需要學(xué)習(xí)的就是思考。
歡迎閱讀我的其它文章狂巢。