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