
調(diào)試是所有程序員都會面臨的問題。如何提高程序員的調(diào)試效率,更好、更快地定位程序中的問題從而加快程序開發(fā)的進度,是大家都很關(guān)注的問題。就如讀者熟知的Windows下的一些調(diào)試工具,如Visual Studio自帶的設(shè)置斷點、單步跟蹤等,都受到了廣大用戶的贊賞。
到此為止,讀者已經(jīng)了解了如何在Linux下使用編輯器編寫代碼,如何使用gcc把代碼編譯成可執(zhí)行文件,還學習了如何使用gdb來調(diào)試程序,那么,所有的工作看似已經(jīng)完成了,為什么還需要make這個工程管理器呢?
在上一小節(jié),讀者已經(jīng)了解到了make項目管理器的強大功能。的確,makefile可以幫助make完成它的使命,但要承認的是,編寫makefile確實不是一件輕松的事,尤其對于一個較大的項目而言更是如此。那么,有沒有一種輕松的手段生成makefile而同時又能讓用戶享受make的優(yōu)越性呢?
通過指定指令的vi操作練習,使讀者能夠熟練使用vi中的常見操作,并且熟悉vi的3種模式,如果讀者能夠熟練掌握實驗內(nèi)容中所要求的內(nèi)容,則表明對vi的操作已經(jīng)很熟練了。
本章是Linux中進行C語言編程的基礎(chǔ),首先講解了C語言編程的關(guān)鍵點,這里關(guān)鍵要了解編輯器、編譯鏈接器、調(diào)試器及項目管理工具等概念。
串口是計算機一種常用的接口,常用的串口有RS-232-C接口。它是于1970年由美國電子工業(yè)協(xié)會(EIA)聯(lián)合貝爾系統(tǒng)、調(diào)制解調(diào)器廠家及計算機終端生產(chǎn)廠家共同制定的用于串行通信的標準,它的全稱是“數(shù)據(jù)終端設(shè)備(DTE)和數(shù)據(jù)通信設(shè)備(DCE)之間串行二進制數(shù)據(jù)交換接口技術(shù)標準”。
由于本章是講解Linux編程開發(fā)的第1章,因此希望讀者更加明確Linux系統(tǒng)調(diào)用和用戶編程接口(API)的概念。在了解了這些之后,會對Linux以及Linux的應(yīng)用編程有更深入的理解。
Google 正在開發(fā)新操作系統(tǒng) Fuchsia,使用名叫 Zircon 的微內(nèi)核。它是作為一個開源項目開發(fā)的,因此外界能跟蹤它的開發(fā)進度。現(xiàn)在,Google 發(fā)布了一個叫“the-book”的文檔頁, 聲明 Fuchsia 不是 Linux,而是一種模塊化的,基于能力的操作系統(tǒng)(A modular, capability-based operating system),然后介紹了新操作系統(tǒng)的子系統(tǒng)和其它信息,包括 Zircon 內(nèi)核、核心、框架、存儲、顯示、媒體、智能、用戶界面、向后兼容等等。Fuchs
在Linux中對目錄和設(shè)備的操作都等同于文件的操作,因此,大大簡化了系統(tǒng)對不同設(shè)備的處理,提高了效率。Linux中的文件主要分為4種:普通文件、目錄文件、鏈接文件和設(shè)備文件。
Fedora是基于RHEL,CentOS,Scientific Linux, 和Oracle Linux的社區(qū)版本。相比RHEL,F(xiàn)edora打包了顯著的更多的軟件包。其中一個原因是,多樣化的社區(qū)參與Fedora的建設(shè);它不只是一家公司。在這個過程中,CentOS用于活動,演示和實驗,因為它是對最終用戶免費提供的,并具有比Fedora的一個更長的發(fā)布周期(通常每隔半年左右發(fā)布一個新版本)。
該漏洞在 CVSS 3.0 下的基本得分為 7.8,它能夠讓本地無權(quán)限的用戶獲取 root 權(quán)限,或者發(fā)動 DoS 讓系統(tǒng)崩潰。4.10.1 以上的版本都存在這個問題,Linux 方面表示,該漏洞將影響 Linux 服務(wù)器,工作站以及虛擬機,但對大多數(shù)容器不造成影響。
本章前面幾節(jié)所述的文件及I/O讀寫都是基于文件描述符的。這些都是基本的I/O控制,是不帶緩存的。而本節(jié)所要討論的I/O操作都是基于流緩沖的,它是符合ANSI C的標準I/O處理,這里有很多函數(shù)讀者已經(jīng)非常熟悉了(如printf()、scantf()函數(shù)等),因此本節(jié)中僅簡要介紹最主要的函數(shù)。
通過編寫文件讀寫及上鎖的程序,進一步熟悉Linux中文件I/O相關(guān)的應(yīng)用開發(fā),并且熟練掌握open()、read()、write()、fcntl()等函數(shù)的使用。
本書在第2章中介紹“ps”的命令時提到過管道,當時指出了管道是Linux中一種很重要的通信方式,它是把一個程序的輸出直接連接到另一個程序的輸入,這里仍以第2章中的“ps –ef | grep ntp”為例,描述管道的通信過程,如圖8.2所示
本章首先講解了系統(tǒng)調(diào)用(System Call)、用戶函數(shù)接口(API)和系統(tǒng)命令之間的聯(lián)系和區(qū)別,這也是貫穿本書的一條主線,本書就是按照系統(tǒng)命令、用戶函數(shù)接口(API)系統(tǒng)調(diào)用的順序逐層深入講解,希望讀者能有一個較為深刻的認識。
進程的概念首先是在20世紀60年代初期由MIT的Multics系統(tǒng)和IBM的TSS/360系統(tǒng)引入的。在40多年的發(fā)展中,人們對進程有過各種各樣的定義?,F(xiàn)列舉較為著名的幾種。
在Linux中創(chuàng)建一個新進程的惟一方法是使用fork()函數(shù)。fork()函數(shù)是Linux中一個非常重要的函數(shù),和讀者以往遇到的函數(shù)有一些區(qū)別,因為它看起來執(zhí)行一次卻返回兩個值。難道一個函數(shù)真的能返回兩個值嗎?希望讀者能認真地學習這一部分的內(nèi)容。
守護進程,也就是通常所說的Daemon進程,是Linux中的后臺服務(wù)進程。它是一個生存期較長的進程,通常獨立于控制終端并且周期性地執(zhí)行某種任務(wù)或等待處理某些發(fā)生的事件。守護進程常常在系統(tǒng)引導載入時啟動,在系統(tǒng)關(guān)閉時終止。
通過編寫多進程程序,使讀者熟練掌握fork()、exec()、wait()和waitpid()等函數(shù)的使用,進一步理解在Linux中多進程編程的步驟。
本章主要介紹進程的控制開發(fā),首先給出了進程的基本概念,Linux下進程的基本結(jié)構(gòu)、模式與類型以及Linux進程管理。進程是Linux中程序運行和資源管理的最小單位,對進程的處理也是嵌入式Linux應(yīng)用編程的基礎(chǔ),因此,讀者一定要牢牢掌握。