佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 用內(nèi)置變量調(diào)試shell腳本的方法

用內(nèi)置變量調(diào)試shell腳本的方法

熱門標簽:網(wǎng)站排名優(yōu)化 AI電銷 百度競價排名 Linux服務(wù)器 呼叫中心市場需求 服務(wù)外包 地方門戶網(wǎng)站 鐵路電話系統(tǒng)

一般的shell腳本的調(diào)試基本都是echo 來處理遇到比較大的腳本的時候,就比較麻煩了,出了問題,還不是很好定位哪行代碼出問題了。
其實shell內(nèi)置的一些變量可以很好的解決這個問題:
$LINENO  $FUNCNAME $BASH_LINENO 這幾個變量記錄了腳本當前的執(zhí)行位置,以及正在執(zhí)行的函數(shù)。具體可以可以man 文檔頁。

實例代碼:a.sh

復制代碼 代碼如下:
#!/bin/bash
abc() {
echo "wo shi abc()"
echo  "func: $FUNCNAME  ln: $LINENO ln2:${BASH_LINENO[1]} brother: ${FUNCNAME[1]}"
}

b.sh:
復制代碼 代碼如下:
#!/bin/bash
../a.sh
abc
cdf() {
abc
}


執(zhí)行結(jié)果:
[root@node2 ~]# ./b.sh
[code]wo shi abc()
func: abc  ln: 5 ln2:0 brother: main
wo shi abc()func: abc  ln: 5 ln2:9 brother: cdf
我在b.sh 里寫了cdf 函數(shù)調(diào)用 abc 函數(shù) ,看到輸出的差別了吧,我們可以利用這些參數(shù)打印出代碼出錯行的位置,以及代碼出錯時,是由哪個函數(shù)調(diào)用的,等等。。。。

您可能感興趣的文章:
  • 如何調(diào)試Linux shell腳本

標簽:蘭州 銅川 湖南 仙桃 衡水 崇左 黃山 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標題《用內(nèi)置變量調(diào)試shell腳本的方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    许昌市| 南召县| 肇源县| 饶平县| 二连浩特市| 哈尔滨市| 米脂县| 上林县| 隆化县| 威宁| 青阳县| 尚义县| 平和县| 金塔县| 昌江| 车致| 台中县| 藁城市| 淮安市| 喀喇沁旗| 鄂伦春自治旗| 东乡族自治县| 台中县| 仲巴县| 太原市| 德钦县| 定日县| 渭源县| 紫阳县| 定边县| 西林县| 南郑县| 广水市| 宁波市| 万全县| 荆门市| 南昌市| 和硕县| 广西| 芒康县| 丘北县|