1.理論上的概念
源代碼是相對目標代碼和可執行代碼而言的。
源代碼就是用匯編語(yǔ)言和高級語(yǔ)言寫(xiě)出來(lái)的地代碼。
目標代碼是指源代碼經(jīng)過(guò)編譯程序產(chǎn)生的能被cpu直接識別二進(jìn)制代碼。
可執行代碼就是將目標代碼連接后形成的可執行文件,當然也是二進(jìn)制的。
2.最直觀(guān)的概念
在這個(gè)網(wǎng)頁(yè)上右鍵鼠標,選擇查看源文件.出來(lái)一個(gè)記事本,里面的內容就是此網(wǎng)頁(yè)的源代碼。
3.源代碼(也稱(chēng)源程序),是指一系列人類(lèi)可讀的計算機語(yǔ)言指令。
在現代程序語(yǔ)言中,源代碼可以是以書(shū)籍或者磁帶的形式出現,但最為常用的格式是文本文件,這種典型格式的目的是為了編譯出計算機程序。計算機源代碼的最終目的是將人類(lèi)可讀的文本翻譯成為計算機可以執行的二進(jìn)制指令,這種過(guò)程叫做編譯,通過(guò)編譯器完成。
4.作用
源代碼主要功用有如下2種作用:
生成目標代碼,即計算機可以識別的代碼。
對軟件進(jìn)行說(shuō)明,即對軟件的編寫(xiě)進(jìn)行說(shuō)明。為數不少的初學(xué)者,甚至少數有經(jīng)驗的程序員都忽視軟件說(shuō)明的編寫(xiě),因為這部分雖然不會(huì )在生成的程序中直接顯示,也不參與編譯。但是說(shuō)明對軟件的學(xué)習、分享、維護和軟件復用都有巨大的好處。因此,書(shū)寫(xiě)軟件說(shuō)明在業(yè)界被認為是能創(chuàng )造優(yōu)秀程序的良好習慣,一些公司也硬性規定必須書(shū)寫(xiě)。
需要指出的是,源代碼的修改不能改變已經(jīng)生成的目標代碼。如果需要目標代碼做出相應的修改,必須重新編譯。
5.代碼組合
源代碼作為軟件的特殊部分,可能被包含在一個(gè)或多個(gè)文件中。一個(gè)程序不必用同一種格式的源代碼書(shū)寫(xiě)。例如,一個(gè)程序如果有C語(yǔ)言庫的支持,那么就可以用C語(yǔ)言;而另一部分為了達到比較高的運行效率,則可以用匯編語(yǔ)言編寫(xiě)。
較為復雜的軟件,一般需要數十種甚至上百種的源代碼的參與。為了降低種復雜度,必須引入一種可以描述各個(gè)源代碼之間聯(lián)系,并且如何正確編譯的系統。在這樣的背景下,修訂控制系統(RCS)誕生了,并成為研發(fā)者對代碼修訂的必備工具之一。
還有另外一種組合:源代碼的編寫(xiě)和編譯分別在不同的平臺上實(shí)現,專(zhuān)業(yè)術(shù)語(yǔ)叫做軟件移植。
6.版權
如果按照源代碼類(lèi)型區分軟件,通常被分為兩類(lèi):自由軟件和非自由軟件。自由軟件一般是不僅可以免費得到,而且公開(kāi)源代碼;相對應地,非自由軟件則是不公開(kāi)源代碼。所有一切通過(guò)非正常手段獲得非自由軟件源代碼的行為都將被視為非法。
7.質(zhì)量
對于計算機而言,并不存在真正意義上的“好”的源代碼;然而作為一個(gè)人,好的書(shū)寫(xiě)習慣將決定源代碼的好壞。源代碼是否具有可讀性,成為好壞的重要標準。軟件文檔則是表明可讀性的關(guān)鍵。
8.效率
雖然我們可以通過(guò)不同的語(yǔ)言來(lái)實(shí)現計算機的同一功能,但在執行效率上則存在不同。普遍規律是:越高級的語(yǔ)言,其執行效率越低。這也是為什么匯編語(yǔ)言生成的文件比用VB語(yǔ)言生成文件普遍要小的原因。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。