對(duì)于哲學(xué)問(wèn)題先有雞還是先有蛋一直是人們爭(zhēng)論的焦點(diǎn),但是從語(yǔ)言學(xué)定義來(lái)說(shuō),沒(méi)有雞如何定義雞蛋,然而不管是先有雞蛋還是先有雞,因?yàn)樗鼈兊难h(huán)依賴,導(dǎo)致了彼此的共生。
對(duì)于軟件行業(yè)來(lái)說(shuō),編程語(yǔ)言和編譯器就很類似雞和雞蛋的關(guān)系。
用編程語(yǔ)言寫出了編譯器,反過(guò)來(lái)用編譯器對(duì)編程語(yǔ)言進(jìn)行了編譯。
表面上來(lái)看,編譯器和編程語(yǔ)言是彼此依賴的,但是更高層面上來(lái)講它們是不斷進(jìn)化的。一開(kāi)始的編程語(yǔ)言不完善,寫出的編譯器也是不完整的,然后我們用不完整的編譯器編譯了編程語(yǔ)言,讓它逐漸變得完整,同時(shí)我們又用變得完整的編程語(yǔ)言,寫出了更加完整的編譯器。
究竟誰(shuí)是最先產(chǎn)生的?
對(duì)于這個(gè)問(wèn)題,一定是現(xiàn)有的編程語(yǔ)言,因?yàn)樽钤绲木幊陶Z(yǔ)言我們可以認(rèn)為它們不需要編譯,因?yàn)樗鼈兛梢灾苯觼?lái)操作硬件,所以應(yīng)該是先有A編程語(yǔ)言,然后用A編程語(yǔ)言編寫了一個(gè)編譯器,這個(gè)編譯器可以編譯B語(yǔ)言,然后B編程語(yǔ)言可以自己編寫出自己的編譯器來(lái)編譯自己。
自舉
一個(gè)人再有力氣也無(wú)法給自己舉起來(lái),但是在軟件編程里面,編譯語(yǔ)言卻可以用自己編寫的編譯器編譯自己,這就叫做自舉。
完成自舉的過(guò)程。
用X語(yǔ)言把那個(gè)Y語(yǔ)言編譯器寫出來(lái)。
用Y語(yǔ)言把編譯器編寫出來(lái),用上面的編譯器進(jìn)行編譯。
Y編譯出來(lái)的編譯器對(duì)Y進(jìn)行編譯,得到新的編譯器。
新的編譯器進(jìn)行用例測(cè)試,沒(méi)問(wèn)題的話,用Y語(yǔ)言寫的新的編譯器就可以對(duì)Y語(yǔ)言編譯,實(shí)現(xiàn)編譯器自舉。
現(xiàn)實(shí)中的例子
做一個(gè)打鐵工具,然后用這個(gè)打鐵工具又可以做出打鐵工具。
用編程語(yǔ)言寫出編輯器,反過(guò)來(lái)再用編輯器去寫編程語(yǔ)言。
有錢了去投資,投資之后有了錢再去投資。
總結(jié)
編譯器本身是一種將一種語(yǔ)言翻譯成另一種語(yǔ)言的工具,至于它本身是如何編寫的,我們其實(shí)并不太關(guān)心,只要它可以準(zhǔn)確快速地幫我們完成翻譯的工作就可以了。
先有雞還是先有蛋并不重要,重要的是我們既可以吃雞,又可以吃雞蛋。