SCO Unix操作系統(tǒng)到Linux的程序移植
Unix操作系統(tǒng)有很多值得學習的地方,這里我們主要介紹Unix操作系統(tǒng)中的SCO Unix操作系統(tǒng)到Linux操作系統(tǒng)的程序移植問題。
要求把一個原先運行在SCO Unix操作系統(tǒng)的柜面系統(tǒng)移植到Red Hat Linux AS平臺上?,F(xiàn)在好像有一個趨勢,金融行業(yè)的的原先運行在SCO下的系統(tǒng)都準備遷移到LINUX下。
下面簡要整理一下,遷移過程中的一些心得體會。
一、SCO Unix操作系統(tǒng)的cc 與LINUX 的gcc的一些差別
總的來說,linux的gcc編譯器相對sco下的cc要嚴格許多。通過這次移植發(fā)現(xiàn)SCO Unix操作系統(tǒng)的cc對程序的要求實在不怎么嚴謹。舉個例子,比如strcpy()函數(shù)應(yīng)該是2個函數(shù),如果你給他3個參數(shù),編譯也能通過。還有,如果一個函數(shù)的參數(shù)應(yīng)該是傳值,你給它傳一個地址,cc也不會報錯。
SCO Unix操作系統(tǒng)的cc與linux的gcc在有關(guān)空指針的處理上的差別是最明顯的。比如,trcpy(),strncpy(),strcmp(),strncmp(),fclose()。在SCO上,如果參數(shù)有一個是空指針,程序不會core,但在LINUX下,這些函數(shù)只要有一個是空指針,程序運行過程中就會core。在移植過程中,我們發(fā)現(xiàn)只要程序運行過程中出現(xiàn)core,十有八九是因為空指針的問題。
因此,移植Unix操作系統(tǒng)的***步,我么就對上述常見的字符串操作函數(shù),做了一層封裝,然后用封裝過的函數(shù)來全局替換原來的函數(shù)。
二、gdb的使用
由于以前沒在liunx下寫過程序,對gdb調(diào)試工具也沒有使用過。這次移植還學會了gdb的一些基本調(diào)試步驟。
gdb 可執(zhí)行程序
b 設(shè)置斷點
r 運行程序
c 端點后重新運行程序
n 執(zhí)行下一條語句
s 進入到函數(shù)體內(nèi)調(diào)試(相對于n)
attach PID 調(diào)試正在運行的程序
三、關(guān)于core文件
在SCO Unix操作系統(tǒng)下,一般程序core時,都會在可執(zhí)行目錄下生成一個core文件,我們可以使用dbx 來查看程序的什么地方出現(xiàn)了core。
移植到LINUX下,一開始,程序core時,怎么都沒有生成core文件。后來,才發(fā)現(xiàn),需要人為設(shè)定core文件所允許的***值。如果沒有設(shè)定,默認是0,也就不會生成core文件。
設(shè)定方法如下:
執(zhí)行 ulimit -c 102400,可以把這個命令放在用戶的登錄shell里面,這樣不用每次登錄時重新設(shè)置了。
使用“gdb 可執(zhí)行程序名 core文件名”可以查看大致在什么地方程序出現(xiàn)core
這樣,我們就完成了對SCO Unix操作系統(tǒng)到Linux操作系統(tǒng)的程序移植的介紹。
【編輯推薦】