在討論程式碼是什麼之前,我們先來談論一下什麼是可執行檔?我們說過,在Linux 系統上面,一個檔案能不能被執行看的是有沒有可執行的那個權限 (具有x permission),不過,Linux 系統上真正認識的可執行檔其實是二進位檔案 (binary program),例如 /usr/bin/passwd, /bin/touch 這些個檔案即為二進位程式碼。
或許你會說 shell scripts 不是也可以執行嗎?其實 shell scripts 只是利用 shell (例如 bash) 這支程式的功能進行一些判斷式,而最終執行的除了 bash 提供的功能外,仍是呼叫一些已經編譯好的二進位程式來執行的呢!當然啦, bash 本身也是一支二進位程式啊!那麼我怎麼知道一個檔案是否為 binary 呢?還記得我們在第七章裡面提到的 file 這個指令的功能嗎?對啦!用他就是了!我們現在來測試一下:
# 先以系統的檔案測試看看: [root@www ~]# file /bin/bash /bin/bash: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/ Linux 2.6.9, dynamically linked (uses shared libs), for GNU/Linux 2.6.9, stripped # 如果是系統提供的 /etc/init.d/syslog 呢? [root@www ~]# file /etc/init.d/syslog /etc/init.d/syslog: Bourne-Again shell script text executable |
看到了吧!如果是 binary 而且是可以執行的時候,他就會顯示執行檔類別 (ELF 32-bit LSB executable),同時會說明是否使用動態函式庫 (shared libs),而如果是一般的 script ,那他就會顯示出 text executables 之類的字樣!
既然 Linux 作業系統真正認識的其實是 binary program,那麼我們是如何做出這樣的一支binary 的程式呢?首先,我們必須要寫程式,用什麼東西寫程式?就是一般的文書處理器啊!鳥哥都喜歡使用vim 來進行程式的撰寫,寫完的程式就是所謂的原始程式碼囉!這個程式碼檔案其實就是一般的純文字檔。在完成這個原始碼檔案的編寫之後,再來就是要將這個檔案『編譯』成為作業系統看的懂得binary program 囉!而要編譯自然就需要『編譯器』來動作,經過編譯器的編譯與連結之後,就會產生一支可以執行的 binary program 囉。
舉個例子來說,在 Linux 上面最標準的程式語言為 C ,所以我使用 C 的語法進行原始程式碼的書寫,寫完之後,以Linux 上標準的 C 語言編譯器 gcc 這支程式來編譯,就可以製作一支可以執行的binary program 囉。整個的流程有點像這樣:
![利用 gcc 編譯器進行程式的編譯流程示意圖 利用 gcc 編譯器進行程式的編譯流程示意圖](http://linux.vbird.org/linux_basic/0520source//source_to_binary.gif)
圖 1.1.1、利用 gcc 編譯器進行程式的編譯流程示意圖"
事實上,在編譯的過程當中還會產生所謂的目標檔 (Object file),這些檔案是以 *.o 的副檔名樣式存在的!至於 C 語言的原始碼檔案通常以 *.c 作為副檔名。此外,有的時候,我們會在程式當中『引用、呼叫』其他的外部副程式,或者是利用其他軟體提供的『函數功能』,這個時候,我們就必須要在編譯的過程當中,將該函式庫給他加進去,如此一來,編譯器就可以將所有的程式碼與函式庫作一個連結 (Link) 以產生正確的執行檔囉。
總之,我們可以這麼說:
- 開放源碼:就是程式碼,寫給人類看的程式語言,但機器並不認識,所以無法執行;
- 編譯器:將程式碼轉譯成為機器看的懂得語言,就類似翻譯者的角色;
- 可執行檔:經過編譯器變成二進位程式後,機器看的懂所以可以執行的檔案。
在我的ubantu 11.04上编译代码是
首先新建源码
vim hello.c
然后在vim里面写源码,这个与windows下写c源码无差异。
然后再编译这个源码
gcc -o hello hello.c
这个的意思是用gcc这个编译器把hello.c源码编译成hello这个可执行文件,存在当下目录
./hello
这是是在