我們擅長(cháng)商業(yè)策略與用戶(hù)體驗的完美結合。
歡迎瀏覽我們的案例。
我們知道計算機的運作離不開(kāi)硬件,但卻無(wú)法直接操作硬件,硬件的驅動(dòng)只能通過(guò)一種稱(chēng)之為“操作系統(OS,Opertating System)的軟件來(lái)管控。Linux 嚴格來(lái)說(shuō)是一個(gè)操作系統(OS)。
使用者沒(méi)有辦法直接操作 Kernel,而是通過(guò) Kernel 的“外殼”程序,也就是所謂的 Shell 來(lái)與 Kernel 溝通。Shell 是一個(gè)使用者與系統的交互界面(Interface),只能通過(guò)命令行(Command line)來(lái)使用系統來(lái)完成工作。因此 ,Shell 最簡(jiǎn)單的定義就是:命令解譯器(Command Interpreter)
將使用者的命令翻譯給內核處理;
同時(shí),將內核處理結果翻譯給使用者。
不同的 OS 使用不同的 Kernel;同一個(gè) kernel 之上,也可以使用不同的 Shell,常見(jiàn)的 Shell 有sh、bash、csh、ksh 等
2、Shell prompt(PS1)與 Carriage Return(CR)的關(guān)系?
成功登錄一個(gè) Shell 終端后,光標左邊部分稱(chēng)之為提示符 Prompt,通常一般用戶(hù)使用 $,管理員用戶(hù)使用 #
Shell Prompt:可以輸入命令了,鍵入命令后,直到讀進(jìn) CR(Carriage Return)字符為止
Carriage Return:可以執行命令了
若從技術(shù)的細節來(lái)看,Shell 會(huì )依據 IFS(Internal Field Seperator)將 Command line 所輸入的文字拆解為”字段”(word/field)。然后再針對特殊字符(meta)先作處理,最后重組整行command line。
3、別人echo,你也echo,試問(wèn) echo 知多少?
echo 將 argument送到標準輸出(stdout),通常顯示在屏幕
stdin 標準輸入
stdout 標準輸出
stderr 標準錯誤輸出
echo -n # 取消換行符echo -e # 啟用反斜杠轉譯
4、雙引號""與單引號''有什么區別?
hard quote:''(單引號),關(guān)閉所有引用
soft quote:""(雙引號),保留$引用
5、var=value? export 前后差在哪?
變量定義:name=value,等號左右兩邊不能使用分隔符。
變量替換:echo ${name}
export變量:export name=value,使變量成為環(huán)境變量
# 本地變量A=B# 取消變量unset A# 環(huán)境變量export A=B
6、exec 跟 source 差在哪?
環(huán)境變量只能從父進(jìn)程到子進(jìn)程單向傳遞。換句話(huà)說(shuō):在子進(jìn)程中環(huán)境如何變更,均不會(huì )影響父進(jìn)程的環(huán)境。
當我們執行一個(gè)shell script時(shí),其實(shí)是先產(chǎn)生一個(gè)sub-shell的子進(jìn)程, 然后sub-shell再去產(chǎn)生命令行的子進(jìn)程。
# 創(chuàng )建子shell執行腳本./1.sh# 當前shell執行source 1.sh# 當前shell執行后退出exec 1.sh
7、( ) 與 { } 差在哪?
( ) 將 command group 置于 sub-shell 執行
{ } 則是在同一個(gè)shell內完成
8、$(()) 與 $() 還有 ${} 差在哪?
# 假設我們定義了一個(gè)變量為:file=/dir1/dir2/dir3/my.file.txt# 我們可以用 ${ } 分別替換獲得不同的值:# 1. shell字符串的非貪婪(最小匹配)左刪除${file#*/} # 拿掉第一條 / 及其左邊的字符串:dir1/dir2/dir3/my.file.txt# 2. shell字符串的貪婪(最大匹配)左刪除${file##*/} # 拿掉最后一條 / 及其左邊的字符串:my.file.txt${file##*.} # 拿掉最后一個(gè) . 及其左邊的字符串:txt# 3. shell字符串的非貪婪(最小匹配)右刪除:${file%/*} # 拿掉最后條 / 及其右邊的字符串:/dir1/dir2/dir3${file%.*} # 拿掉最后一個(gè) . 及其右邊的字符串:/dir1/dir2/dir3/my.file# 4. shell字符串的貪婪(最大匹配)右刪除:${file%%/*} # 拿掉第一條 / 及其右邊的字符串:(空值)${file%%.*} # 拿掉第一個(gè) . 及其右邊的字符串:/dir1/dir2/dir3/my記憶的方法為:# 是去掉左邊(在鍵盤(pán)上 # 在 $ 之左邊)% 是去掉右邊(在鍵盤(pán)上 % 在 $ 之右邊)單一符號是最小匹配﹔兩個(gè)符號是最大匹配。
# 5. shell字符串取子串:${file:0:5}:提取最左邊的 5 個(gè)字節:/dir1${file:5:5}:提取第 5 個(gè)字節右邊的連續 5 個(gè)字節:/dir2# 6. shell字符串變量值的替換:${file/dir/path}:將第一個(gè) dir 提換為 path:/path1/dir2/dir3/my.file.txt${file//dir/path}:將全部 dir 提換為 path:/path1/path2/path3/my.file.txt# 7. ${}還可針對變量的不同狀態(tài)(沒(méi)設定、空值、非空值)進(jìn)行賦值:${file-my.file.txt} :假如 $file 沒(méi)有設定,則使用 my.file.txt 作傳回值。(空值及非空值時(shí)不作處理) ${file:-my.file.txt} :假如 $file 沒(méi)有設定或為空值,則使用 my.file.txt 作傳回值。(非空值時(shí)不作處理)${file+my.file.txt} :假如 $file 設為空值或非空值,均使用 my.file.txt 作傳回值。(沒(méi)設定時(shí)不作處理)${file:+my.file.txt} :若 $file 為非空值,則使用 my.file.txt 作傳回值。(沒(méi)設定及空值時(shí)不作處理)${file=my.file.txt} :若 $file 沒(méi)設定,則使用 my.file.txt 作傳回值,同時(shí)將 $file 賦值為 my.file.txt 。(空值及非空值時(shí)不作處理)${file:=my.file.txt} :若 $file 沒(méi)設定或為空值,則使用 my.file.txt 作傳回值,同時(shí)將 $file 賦值為 my.file.txt 。(非空值時(shí)不作處理)${file?my.file.txt} :若 $file 沒(méi)設定,則將 my.file.txt 輸出至 STDERR。(空值及非空值時(shí)不作處理)${file:?my.file.txt} :若 $file 沒(méi)設定或為空值,則將 my.file.txt 輸出至 STDERR。(非空值時(shí)不作處理)tips:以上的理解在于, 你一定要分清楚 unset 與 null 及 non-null 這三種賦值狀態(tài).一般而言, : 與 null 有關(guān), 若不帶 : 的話(huà), null 不受影響, 若帶 : 則連 null 也受影響.
# 8. 計算shell字符串變量的長(cháng)度:${#var}${#var} 可計算出變量值的長(cháng)度:${#file} 可得到 27 ,因為 /dir1/dir2/dir3/my.file.txt 剛好是 27 個(gè)字節...# 9. bash數組(array)的處理方法數組:A=(a b c d)引用數組:${A[@]}${A[*]}訪(fǎng)問(wèn)數組成員${A[0]}計算數組長(cháng)度${#A[@]}${#A[*]}數組重新賦值A[2]=xyz# 10.$(( ))是用來(lái)做整數運算的 a=5;b=7;c=2;echo $(( a + b * c))
9、$@ 與 $* 區別在哪?
"$@" 則可得到 “p1” “p2 p3” “p4” 這三個(gè)不同的詞段
"$*" 則可得到 “p1 p2 p3 p4” 這一整串單一的詞段
10、&& 與 || 差在哪?
1、test命令有兩種形式
test expression
[ expression ]
2、bash的test目前支持三種測試對象
string:字符串
integer:整數
file:文件
3、當 expression 為真是返回 0(true) ,否則返回 非0(false)
command1 && command2 command2 只有在 command1 的RV為0(True)的條件下執行。
command1 || command2 command2只有在command1的RV為非0(False)的條件下執行。
4、先替換變量再比較
A=123[ -n "$A" ] && ([ "$A" -lt 100 ] || echo "too big")unset A
11、> 與 < 差在哪?
0: Standard Input(STDIN)
1: Standard Output (STDOUT)
2: Standard Error Output(STDERR)
我們可用 < 來(lái)改變讀進(jìn)的數據信道(stdin),使之從指定的檔案讀進(jìn)。
我們可用 > 來(lái)改變送出的數據信道(stdout, stderr),使之輸出到指定的檔案。
ls my.file no.such.file 1> file.out 2>file.err# 2>&1 就是將stderr并進(jìn)stdout做輸出ls my.file no.such.file 1> file.out 2>&1# /dev/null 空l(shuí)s my.file no.such.file >/dev/null 2>&1cat < file > file# 在 IO Redirection 中,stdout 與 stderr 的管道會(huì )先準備好,才會(huì )從 stdin 讀進(jìn)資料。# 也就是說(shuō),在上例中,> file 會(huì )先將 file 清空,然后才讀進(jìn) < file , # 但這時(shí)候檔案已經(jīng)被清空了,因此就變成讀不進(jìn)任何數據了
12、你要if還是case呢?
# ifecho -n "Do you want to continue?(Yes/No):"read YNif [ "$YN"=Y -o "$YN"=y -o "$YN"="Yes" -o "$YN"="yes" -o "$YN"="YES"];thenecho "continue"elseexit 0fi# caseecho -n "Do you want to continue?(Yes/No):"read YNcase "$YN" in[Yy]|[Yy][Ee][Ss])echo "continue";;*)exit 0esac
13、for what? while與until差在哪?
# forfor ((i=1;i<=10;i++))doecho "num is $i"done# whilenum=1while [ "$num" -le 10 ]; doecho "num is $num"num=$(($num + 1))done# untilnum=1until [ "$num" -gt 10 ]; doecho "num is $num"num=$(($nu + 1))done
break 是結束 loop
return 是結束 function
exit 是結束 script/shell
?。?a href="http://www.wxlp666.cn/wechat/">邯鄲小程序開(kāi)發(fā))
小米應用商店發(fā)布消息稱(chēng) 持續開(kāi)展“APP 侵害用戶(hù)權益治理”系列行動(dòng) 11:37:04
騰訊云與CSIG成立政企業(yè)務(wù)線(xiàn) 加速數字技術(shù)在實(shí)體經(jīng)濟中的落地和應用 11:34:49
樂(lè )視回應還有400多人 期待新的朋友加入 11:29:25
亞馬遜表示 公司正在將其智能購物車(chē)擴展到馬薩諸塞州的一家全食店 10:18:04
三星在元宇宙平臺推出游戲 玩家可收集原材料制作三星產(chǎn)品 09:57:29
特斯拉加州San Mateo裁減229名員工 永久關(guān)閉該地區分公司 09:53:13