關(guān)于shell腳本#!的說明

Unix環(huán)境下的shell腳本通常都是#!/bin/sh開頭,那么這句描述符究竟是什么含義呢窘拯,我試圖解答這個問題。

#!出現(xiàn)的位置

首先#!必須出現(xiàn)在shell腳本的開頭位置,后面跟一個shell解析器,比如/bin/sh拌倍,或者/bin/bash,或者/usr/bin/ksh, 等等.

看一個例子

$ cat a.sh
#!/bin/bash
readlink /proc/$$/exe
$ ./a.sh
/bin/bash

我們看到 a.sh使用的可執(zhí)行程序是/bin/bash噪径,這個/bin/bash是在a.sh文件里面通過#!指定的柱恤。

再看另一個例子a.out

$ cat a.c
#include <stdio.h>

int main()
{
    printf("Hello a.out!\n");
    return 0;
}
$ gcc t.c
$ ./a.out
Hello a.out!
$ bash ./a.out
./a.out: ./a.out: cannot execute binary file

a.out是一個可執(zhí)行程序(ELF格式),它可以獨自運行找爱,但是不能通過一個shell來運行梗顺。

分析

#!實際上就是文件的魔數(shù)(magic number)
我們知道ELF格式為文件頭4個字符是".ELF",即(0x 7f 45 4c 46)车摄,而其實字符"#!"是shell腳本文件的魔數(shù)荚守,即(0x 23 21),因為shell腳本是文本文件练般,#!就是兩個可讀的魔數(shù)字符。

這個魔數(shù)是干什么用的呢锈候?它是被操作系統(tǒng)exec系列函數(shù)使用的薄料,exec函數(shù)需要加載一個文件時,它會讀取文件開頭魔數(shù)域泵琳,如果是".ELF",那么就是一個ELF格式的可執(zhí)行文件乱凿,如果是"#!"那么就是一個腳本文件穷娱,然后再從"#!"后面繼續(xù)讀取腳本解析器,最后調(diào)用腳本解析器可執(zhí)行程序蛔垢,并把腳本本身作為參數(shù)傳遞給他。

注意

  1. 如果shell腳本的命令行中已經(jīng)有腳本解析器了迫悠,那么腳本中的"#!"內(nèi)容將被丟棄鹏漆,而采用命令行中的解析器。
    例如
$ /bin/tcsh a.sh
/bin/tcsh
$ /usr/local/bin/pdksh a.sh
/usr/local/bin/pdksh
$ /bin/ksh a.sh
/bin/readlink
  1. 如果shell腳本中沒有魔數(shù)"#!"怎么辦
    shell使用當(dāng)前的shell來處理创泄。
$ cat a.sh
readlink /proc/$$/exe
$ ./a.sh
/bin/bash
$ echo $SHELL
/bin/bash
  1. 對于一般文件的加載過程
$ ./file格式

當(dāng)前shell會讀取文件file的魔數(shù)

  • 如果是".ELF"艺玲,二進(jìn)制可執(zhí)行程序,安裝ELF文件處理
    • 區(qū)分.o, .so, etc.
  • 如果是"#!"鞠抑,那么加載魔數(shù)后面指定的可執(zhí)行程序饭聚,并把file作為參數(shù)傳遞過去。
  • 其它:file會作為一個當(dāng)前shell類型的腳本運行搁拙,即試圖把path_to_file的內(nèi)容按照腳本來解釋執(zhí)行秒梳。
  1. sh file格式
    注意這種格式要求file必須是一個shell腳本,不能是二進(jìn)制可執(zhí)行程序箕速。
    如果file是一個二進(jìn)制格式文件酪碘,則可以采用格式:sh -c file
    對于后一種格式,其實不管file是一個腳本還是一個二進(jìn)制可執(zhí)行程序弧满,都可以運行婆跑。

我也不清楚為什么sh file格式不能支持file是二進(jìn)制可執(zhí)行程序,理論上sh還是可以去分析file的魔數(shù)庭呜,從而判斷file的類型滑进,然后做區(qū)分處理。

Refer to:

https://en.wikipedia.org/wiki/Shebang_(Unix)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末募谎,一起剝皮案震驚了整個濱河市扶关,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌数冬,老刑警劉巖节槐,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異拐纱,居然都是意外死亡铜异,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進(jìn)店門秸架,熙熙樓的掌柜王于貴愁眉苦臉地迎上來揍庄,“玉大人,你說我怎么就攤上這事东抹÷熳樱” “怎么了沃测?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長食茎。 經(jīng)常有香客問我蒂破,道長,這世上最難降的妖魔是什么别渔? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任附迷,我火速辦了婚禮,結(jié)果婚禮上钠糊,老公的妹妹穿的比我還像新娘挟秤。我一直安慰自己,他們只是感情好抄伍,可當(dāng)我...
    茶點故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布艘刚。 她就那樣靜靜地躺著,像睡著了一般截珍。 火紅的嫁衣襯著肌膚如雪攀甚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天岗喉,我揣著相機(jī)與錄音秋度,去河邊找鬼。 笑死钱床,一個胖子當(dāng)著我的面吹牛荚斯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播查牌,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼事期,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了纸颜?” 一聲冷哼從身側(cè)響起兽泣,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎胁孙,沒想到半個月后唠倦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡涮较,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年稠鼻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狂票。...
    茶點故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡枷餐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情毛肋,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布屋剑,位于F島的核電站润匙,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏唉匾。R本人自食惡果不足惜孕讳,卻給世界環(huán)境...
    茶點故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望巍膘。 院中可真熱鬧厂财,春花似錦、人聲如沸峡懈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肪康。三九已至荚恶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間磷支,已是汗流浹背谒撼。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留雾狈,地道東北人廓潜。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像善榛,于是被迫代替她去往敵國和親辩蛋。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,678評論 2 354

推薦閱讀更多精彩內(nèi)容