日本免费全黄少妇一区二区三区-高清无码一区二区三区四区-欧美中文字幕日韩在线观看-国产福利诱惑在线网站-国产中文字幕一区在线-亚洲欧美精品日韩一区-久久国产精品国产精品国产-国产精久久久久久一区二区三区-欧美亚洲国产精品久久久久

SCO UNIX到Linux操作系統(tǒng)的程序移植問題

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

    推薦閱讀