1.源程式的編譯
在linux下面,如果要編譯乙個c語言源程式,我們要使用gnu的gcc編譯器. 下面我們以乙個例項來說明如何使用gcc編譯器.
假設我們有下面乙個非常簡單的源程式(hello.c):
int main(int argc,char **argv)
要編譯這個程式,我們只要在命令列下執行:
gcc -o hello hello.c
gcc 編譯器就會為我們生成乙個hello的可執行檔案.執行./hello就可以看到程式的輸出結果了.命令列中 gcc表示我們是用gcc來編譯我們的源程式,-o 選項表示我們要求編譯器給我們輸出的可執行檔名為hello 而hello.c是我們的源程式檔案.
gcc編譯器有許多選項,一般來說我們只要知道其中的幾個就夠了. -o選項我們已經知道了,表示我們要求輸出的可執行檔名. -c選項表示我們只要求編譯器輸出目標**,而不必要輸出可執行檔案. -g選項表示我們要求編譯器在編譯的時候提供我們以後對程式進行除錯的資訊.
知道了這三個選項,我們就可以編譯我們自己所寫的簡單的源程式了,如果你想要知道更多的選項,可以檢視gcc的幫助文件,那裡有著許多對其它選項的詳細說明.
2.makefile的編寫
假設我們有下面這樣的乙個程式,源**如下:
/* main.c */
#include "mytool1.h"
#include "mytool2.h"
int main(int argc,char **argv)
/* mytool1.h */
#ifndef _mytool_1_h
#define _mytool_1_h
void mytool1_print(char *print_str);
#endif
/* mytool1.c */
#include "mytool1.h"
void mytool1_print(char *print_str)
/* mytool2.h */
#ifndef _mytool_2_h
#define _mytool_2_h
void mytool2_print(char *print_str);
#endif
/* mytool2.c */
#include "mytool2.h"
void mytool2_print(char *print_str)
當然由於這個程式是很短的我們可以這樣來編譯
gcc -c main.c
gcc -c mytool1.c
gcc -c mytool2.c
gcc -o main main.o mytool1.o mytool2.o
這樣的話我們也可以產生main程式,而且也不時很麻煩.但是如果我們考慮一下如果有一天我們修改了其中的乙個檔案(比如說mytool1.c)那麼我們難道還要重新輸入上面的命令?也許你會說,這個很容易解決啊,我寫乙個shell指令碼,讓她幫我去完成不就可以了.是的對於這個程式來說,是可以起到作用的.但是當我們把事情想的更複雜一點,如果我們的程式有幾百個源程式的時候,難道也要編譯器重新乙個乙個的去編譯?
為此,聰明的程式設計師們想出了乙個很好的工具來做這件事情,這就是make.我們只要執行以下make,就可以把上面的問題解決掉.在我們執行make之前,我們要先編寫乙個非常重要的檔案.--makefile.對於上面的那個程式來說,可能的乙個makefile的檔案是:
# 這是上面那個程式的makefile檔案
main:main.o mytool1.o mytool2.o
gcc -o main main.o mytool1.o mytool2.o
main.o:main.c mytool1.h mytool2.h
gcc -c main.c
mytool1.o:mytool1.c mytool1.h
gcc -c mytool1.c
mytool2.o:mytool2.c mytool2.h
gcc -c mytool2.c
有了這個makefile檔案,不過我們什麼時候修改了源程式當中的什麼檔案,我們只要執行make命令,我們的編譯器都只會去編譯和我們修改的檔案有關的檔案,其它的檔案她連理都不想去理的.
下面我們學習makefile是如何編寫的.
在makefile中也#開始的行都是注釋行.makefile中最重要的是描述檔案的依賴關係的說明.一般的格式是:
target: components
tab rule
第一行表示的是依賴關係.第二行是規則.
比如說我們上面的那個makefile檔案的第二行
main:main.o mytool1.o mytool2.o
表示我們的目標(target)main的依賴物件(components)是main.o mytool1.o mytool2.o 當倚賴的物件在目標修改後修改的話,就要去執行規則一行所指定的命令.就象我們的上面那個makefile第三行所說的一樣要執行 gcc -o main main.o mytool1.o mytool2.o 注意規則一行中的tab表示那裡是乙個tab鍵
makefile有三個非常有用的變數.分別是$@,$^,$《代表的意義分別是:
$@--目標檔案,$^--所有的依賴檔案,$<--第乙個依賴檔案.
如果我們使用上面三個變數,那麼我們可以簡化我們的makefile檔案為:
# 這是簡化後的makefile
main:main.o mytool1.o mytool2.o
gcc -o $@ $^
main.o:main.c mytool1.h mytool2.h
gcc -c $<
mytool1.o:mytool1.c mytool1.h
gcc -c $<
mytool2.o:mytool2.c mytool2.h
gcc -c $<
經過簡化後我們的makefile是簡單了一點,不過人們有時候還想簡單一點.這裡我們學習乙個makefile的預設規則
.c.o:
gcc -c $<
這個規則表示所有的 .o檔案都是依賴與相應的.c檔案的.例如mytool.o依賴於mytool.c這樣makefile還可以變為:
# 這是再一次簡化後的makefile
main:main.o mytool1.o mytool2.o
gcc -o $@ $^
.c.o:
gcc -c $<
好了,我們的makefile 也差不多了,如果想知道更多的關於makefile規則可以檢視相應的文件.
3.程式庫的鏈結
試著編譯下面這個程式
/* temp.c */
#include
說明了. 如果我們要write這個函式的說明,當我們執行man write時,輸出的結果卻不是我們所需要的. 因為我們要的是write這個函式的說明,可是出來的卻是write這個命令的說明.為了得到write的函式說明我們要用 man 2 write. 2表示我們用的write這個函式是系統呼叫函式,還有乙個我們常用的是3表示函式是c的庫函式.
記住不管什麼時候,man都是我們的最好助手.
Linux下面如何安裝Django
首先你需要肯定你的機子上裝了python 現在ubuntu已經自帶,所以不必操心 當然你可以在你的機子下測試一下,只需在terminal下輸入python 如果出現下面的介面就說明你機子已經裝了python plain view plain copy python 2.7.3 default,aug...
Linux下面如何執行 SH檔案
乙個中等水平的linux使用者一定少不了經常執行.sh檔案,當然了,你可以在圖形介面下面直接雙擊該檔案,但無疑比較浪費時間。現在介紹第一種方法 在ubuntu下的 首先你要開啟乙個終端。然後輸入sudo su 隨後輸入密碼。這樣就取得了root使用者許可權。然後找到那個檔案 當然是在終端裡面用命令找...
Linux下面如何用tcpdump抓包
很多時候我們的系統部署在linux系統上面,在一些情況下定位問題就需要檢視各個系統之間傳送資料報文是否正常,下面我就簡單講解一下如何使用tcpdump抓包 tcpdump是linux下面的乙個開源的抓包工具,和windows下面的wireshark抓包工具一樣,支援抓取指定網口 指定目的位址 指定源...