编程风格
过程式编程,目的解决问题
指令组织数据,指令的堆砌
为了完成复杂的任务
顺序执行:遍历的方式执行,逐个运行
选择执行:有一种选择标准,结果只能有一种选择,只执行某些 代码片段
循环执行:对一类对象逐个运行相同的运算,类似于 拉磨 的方式,某些代码连续执行多次
对象式编程:
数据为中心
程序执行的方式
编译:先翻译后执行,先将高级语言转换为目标代码: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权限 [[email protected] tmp]# chmod +x adduser.sh [[email protected] 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
时间: 2024-10-16 20:01:31