编程风格

    过程式编程,目的解决问题

        指令组织数据,指令的堆砌

        为了完成复杂的任务

            顺序执行:遍历的方式执行,逐个运行

            选择执行:有一种选择标准,结果只能有一种选择,只执行某些 代码片段

            循环执行:对一类对象逐个运行相同的运算,类似于 拉磨 的方式,某些代码连续执行多次


    对象式编程:

        数据为中心


程序执行的方式

    编译:先翻译后执行,先将高级语言转换为目标代码:C,java程序 --> 编译 --> 目标代码

    解释:边翻译边执行,为避免语法、逻辑等错误,一般先进行语法检查 Shell,java,perl,python程序 --> 解释 --> 目标代码

    

bash:过程式编程、解释执行

    纯文本格式

    cpu上运行是由magic number指定的解释器

    由解释器执行文本


选择执行

    在由if指定的条件中有2种可能,执行状态结果为0,或执行状态结果不为0的结果。

     单分支条件判断

if 条件;那么
    条件的执行状态结果为0
结束

或

if 条件
那么
    条件的执行状态结果为0
结束

        2分支条件判断

if 条件;那么
    条件的执行状态结果为0
否则
    条件的执行状态结果不为0
结束

或

if 条件
那么
    条件的执行状态结果为0
否则
    条件的执行状态结果不为0
结束


例如:

如果用户存在,则添加
# vim adduser.sh

#!/bin/bash
#

##判断向脚本传递的参数是否小于1

if [ $# -lt 1 ]
then
echo "At least one arguments."
exit 1  ##如果向脚本传递的参数小于1,就退出 
fi

##小于1退出,则能继续执行的为>=1

##判断用户是否存在
if id $1 &> /dev/null; then
    #条件的执行状态结果为0,表示为存在
    echo "$1 exists."
    #存在时,退出,返回0
    exit 0
#否则
else
    #条件的执行状态结果不为0,表示为不存在
    useradd $1 &> /dev/null
    #如果添加不成功,显示用户名不合法
    [ $? -eq 0 ] || echo "User name is not legal" && exit 1
    #如果执行成功,添加密码
    echo "$1" | passwd --stdin $1 > /dev/null 2>&1
    #添加密码成功时,返回0
    [ $? -eq 0 ] && exit 0
    #添加密码不成功时,返回1
    exit 1 
#结束
fi

给予x权限
[root@izpo45bh60h6bsz tmp]# chmod +x adduser.sh 
[root@izpo45bh60h6bsz tmp]# ls -l adduser.sh
-rwxr-xr-x 1 root root 835 Aug  5 16:37 adduser.sh

执行
./adduser.sh user::::::::::::::::::::::::::
User name is not legal