>운영 및 유지보수 >리눅스 운영 및 유지 관리 >쉘 스크립트에 관한 13가지 기본 질문

쉘 스크립트에 관한 13가지 기본 질문

Linux中文社区
Linux中文社区앞으로
2023-08-03 15:03:001495검색

쉘 스크립트에 관한 13가지 기본 질문

1. 왜 쉘이라고 부르나요?

우리는 컴퓨터의 작동이 하드웨어와 분리될 수 없다는 것을 알고 있지만 하드웨어를 직접 작동시킬 수는 없습니다. 엄밀히 말하면 Linux는 "운영 체제(OS)"라는 소프트웨어에 의해서만 제어될 수 있습니다. 운영체제(OS)

사용자가 커널을 직접 조작할 수는 없지만, 소위 쉘이라고 불리는 커널의 "쉘" 프로그램을 통해 커널과 통신합니다. 시스템은 명령줄을 통해서만 작업을 완료하는 데 사용할 수 있습니다. 따라서 Shell의 가장 간단한 정의는 다음과 같습니다. 명령 해석기(Command Interpreter)

  • 처리를 위해 사용자 명령을 커널로 변환합니다. 동시에 커널 처리 결과가 사용자에게 전달됩니다.

  • 서로 다른 OS는 서로 다른 커널을 사용하며, 공통 쉘에는 sh, bash 및 csh 등이 포함됩니다.

    2. 쉘 프롬프트(PS1)와 캐리지 리턴(CR)은 어떤 관계가 있나요?

    셸 터미널에 성공적으로 로그인한 후 커서 왼쪽 부분을 프롬프트 프롬프트라고 하며, 이는 일반적으로 일반 사용자가 사용합니다. $,管理员用户使用#

    • 셸 프롬프트: 명령을 입력한 후 명령을 입력할 수 있습니다. , 명령이 입력될 때까지 CR(캐리지 리턴)을 읽습니다. 문자

    • 캐리지 리턴: 명령을 실행할 수 있습니다.

    기술적인 세부 사항을 보면 Shell이 ​​텍스트를 분해합니다. IFS(내부 필드 구분자) "(단어/필드)를 기반으로 "필드"에 명령줄에 입력됩니다. 그런 다음 특수 문자(메타)가 먼저 처리되고 마지막으로 전체 명령줄이 재구성됩니다.

    3. 에코에 대해 얼마나 알고 계시나요?

    echo는 일반적으로 화면에 표시되는 표준 출력(stdout)으로 인수를 보냅니다.

    stdin 표준 입력
    stdout 표준 출력
    stderr 표준 오류 출력

    echo -n  # 取消换行符
    echo -e  # 启用反斜杠转译

    4. 큰따옴표 ""와 작은따옴표 ''의 차이점은 무엇입니까?

    • 큰따옴표: ''(작은따옴표), 모든 참조 닫기''(单引号),关闭所有引用

    • soft quote:""(双引号),保留$引用

    5、var=value? export 前后差在哪?

    • 变量定义:name=value,等号左右两边不能使用分隔符。

    • 变量替换:echo ${name}

    🎜소프트 인용문: ""(큰따옴표) , 예약됨 $Quote🎜
🎜🎜5.var=value? 차이점은 무엇인가요? 🎜🎜🎜🎜🎜변수 정의: 이름=값 등호의 왼쪽과 오른쪽에는 구분 기호를 사용할 수 없습니다. 🎜🎜🎜변수 대체: 에코 ${이름 }🎜
  • export变量:export name=value,使变量成为环境变量

  • # 本地变量
    A=B
    # 取消变量
    unset A
    # 环境变量export A=B

    6、exec 跟 source 差在哪?

    环境变量只能从父进程到子进程单向传递。换句话说:在子进程中环境如何变更,均不会影响父进程的环境。
    当我们执行一个shell script时,其实是先产生一个sub-shell的子进程, 然后sub-shell再去产生命令行的子进程。关注Linux中文社区

    # 创建子shell执行脚本
    ./1.sh
    # 当前shell执行
    source 1.sh
    # 当前shell执行后退出
    exec 1.sh

    7、( ) 与 { } 差在哪?

    ( )将 command group 置于 sub-shell 执行
    { }则是在同一个shell内完成

    8、$(()) 与 $() 还有 ${} 差在哪?

    # 假设我们定义了一个变量为:
    file=/dir1/dir2/dir3/my.file.txt
    # 我们可以用 ${ } 分别替换获得不同的值:
    
    # 1. shell字符串的非贪婪(最小匹配)左删除
    ${file#*/} # 拿掉第一条 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt
    # 2. shell字符串的贪婪(最大匹配)左删除
    ${file##*/} # 拿掉最后一条 / 及其左边的字符串:my.file.txt
    ${file##*.} # 拿掉最后一个 . 及其左边的字符串:txt
    # 3. shell字符串的非贪婪(最小匹配)右删除:
    ${file%/*} # 拿掉最后条 / 及其右边的字符串:/dir1/dir2/dir3
    ${file%.*} # 拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file
    # 4. shell字符串的贪婪(最大匹配)右删除:
    ${file%%/*} # 拿掉第一条 / 及其右边的字符串:(空值)
    ${file%%.*} # 拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my
    
    记忆的方法为:
    # 是去掉左边(在键盘上 # 在 $ 之左边)
    % 是去掉右边(在键盘上 % 在 $ 之右边)
    单一符号是最小匹配﹔两个符号是最大匹配。

    # 5. shell字符串取子串:
    ${file:0:5}:提取最左边的 5 个字节:/dir1
    ${file:5:5}:提取第 5 个字节右边的连续 5 个字节:/dir2
    
    # 6. shell字符串变量值的替换:
    ${file/dir/path}:将第一个 dir 提换为 path:/path1/dir2/dir3/my.file.txt
    ${file//dir/path}:将全部 dir 提换为 path:/path1/path2/path3/my.file.txt
    
    # 7. ${}还可针对变量的不同状态(没设定、空值、非空值)进行赋值:
    ${file-my.file.txt} :假如 $file 没有设定,则使用 my.file.txt 作传回值。(空值及非空值时不作处理) 
    ${file:-my.file.txt} :假如 $file 没有设定或为空值,则使用 my.file.txt 作传回值。(非空值时不作处理)
    ${file+my.file.txt} :假如 $file 设为空值或非空值,均使用 my.file.txt 作传回值。(没设定时不作处理)
    ${file:+my.file.txt} :若 $file 为非空值,则使用 my.file.txt 作传回值。(没设定及空值时不作处理)
    ${file=my.file.txt} :若 $file 没设定,则使用 my.file.txt 作传回值,同时将 $file 赋值为 my.file.txt 。(空值及非空值时不作处理)
    ${file:=my.file.txt} :若 $file 没设定或为空值,则使用 my.file.txt 作传回值,同时将 $file 赋值为 my.file.txt 。(非空值时不作处理)
    ${file?my.file.txt} :若 $file 没设定,则将 my.file.txt 输出至 STDERR。(空值及非空值时不作处理)
    ${file:?my.file.txt} :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。(非空值时不作处理)
    
    tips:
    以上的理解在于, 你一定要分清楚 unset 与 null 及 non-null 这三种赋值状态.
    一般而言, : 与 null 有关, 若不带 : 的话, null 不受影响, 若带 : 则连 null 也受影响.

    # 8. 计算shell字符串变量的长度:${#var}
    ${#var} 可计算出变量值的长度:
    ${#file} 可得到 27 ,因为 /dir1/dir2/dir3/my.file.txt 刚好是 27 个字节...
    
    # 9. bash数组(array)的处理方法
    数组:
    A=(a b c d)
    引用数组:
    ${A[@]}
    ${A[*]}
    访问数组成员
    ${A[0]}
    计算数组长度
    ${#A[@]}
    ${#A[*]}
    数组重新赋值
    A[2]=xyz
    
    # 10.$(( ))是用来做整数运算的 
    a=5;b=7;c=2;
    echo $(( a + b * c))

    9、$@ 与 $* 区别在哪?

    • "$@"则可得到 “p1” “p2 p3” “p4” 这三个不同的词段

    • "$*""p1 p2 p3 p4"와 같은 단일 문구 전체 ​​문자열을 얻을 수 있습니다

    • 또한 공개 계정 Linux를 검색하여 백그라운드에서 "git books"라고 답하는 방법을 배우고 깜짝 선물 패키지를 받으세요. .

    10. &&와 ||의 차이점은 무엇인가요?

    1 테스트 명령에는 두 가지 형식이 있습니다

    • test 표현식

    • [ 표현식 ]

    2.

    문자열: 문자열
    • 정수: 정수
    • 파일: 파일

    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、> 与 325606de74529776dd96c6d329ce7280 来改变送出的数据信道(stdout, stderr),使之输出到指定的档案。
    ls my.file no.such.file 1> file.out 2>file.err
    # 2>&1 就是将stderr并进stdout做输出
    ls my.file no.such.file 1> file.out 2>&1
    # /dev/null 空
    ls my.file no.such.file >/dev/null 2>&1
    
    cat < file > file
    # 在 IO Redirection 中,stdout 与 stderr 的管道会先准备好,才会从 stdin 读进资料。
    # 也就是说,在上例中,> file 会先将 file 清空,然后才读进 < file , 
    # 但这时候档案已经被清空了,因此就变成读不进任何数据了

    12、你要if还是case呢?

    # if
    echo -n "Do you want to continue?(Yes/No):"
    read YN
    if [ "$YN"=Y -o "$YN"=y -o "$YN"="Yes" -o "$YN"="yes" -o "$YN"="YES"];then
    echo "continue"
    else
    exit 0
    fi
    
    # case
    echo -n "Do you want to continue?(Yes/No):"
    read YN
    case "$YN" in
    [Yy]|[Yy][Ee][Ss])
    echo "continue"
    ;;
    *)
    exit 0
    esac

    13、for what? while与until差在哪?

    # for
    for ((i=1;i<=10;i++))
    do
    echo "num is $i"
    done
    
    # while
    num=1
    while [ "$num" -le 10 ]; do
    echo "num is $num"
    num=$(($num + 1))
    done
    
    # until
    num=1
    until [ "$num" -gt 10 ]; do
    echo "num is $num"
    num=$(($nu + 1))
    done
    • break 是结束 loop

    • return 是结束 function

    • exit 是结束 script/shell

    위 내용은 쉘 스크립트에 관한 13가지 기본 질문의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    이 기사는 Linux中文社区에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제