算法及shell脚本编程基础

简介:

bash存在多命令执行的特性,例如:# COMMAND1 $(COMMAND2);还有进程之间的通信(IPC):# COMMAND1 | COMMAND2…

一、命令执行结构与算法

命令执行中,存在顺序执行结构:分号分隔 # COMMAND1 ; COMMAND2 ; …。同时存在选择执行结构:逻辑运算与、或、非、异或,其中最主要的为选择执行结构,具体讨论如下。

1、与:逻辑乘法 &&

状态返回值:0对应TRUE,1-255对应FALSE

具体算法为:True &&true == true

            True && false == false

            False &&true == false

            False && false == false

与运算存在短路逻辑运算:只要第一个逻辑操作数为假,则其逻辑操作结果一定为假。例如COMMAND1 && COMMAND2,解释为:如果COMMAND1能够成功执行,则COMMAND2会被执行;如果COMMAND1能够成功执行,则COMMAND2会被执行

2、或:逻辑加法 ||

具体算法为:True || true == true

            True || false == true

            False || true == true

            False || false == false

或的短路逻辑运算:主要有一个逻辑操作数为true,则其逻辑运算结果一定为true。例如COMMAND1 || COMMAND2,解释为:如果COMMAND1能够成功执行,则COMMAND2就没有必要执行;如果COMMAND1执行失败,则COMMAND2不会被执行

3、非:逻辑取反  !  

具体算法为: !COMMAND (!true = false、!false = true)

综合以上三点,可以得到:

逻辑运算符优先级: !> && > || 

 !COMMAND1 &&COMMAND2相当于 COMMAND1 ||COMMAND2,解释为:如果COMMAND1能够成功执行,则COMMAND2就没有必要执行;如果COMMAND1执行失败,则COMMAND2不会被执行 

 !COMMAND1 || COMMAND2相当于 COMMAND1 && COMMAND2,解释为: 如果COMMAND1能够成功执行,则COMMAND2会被执行;如果COMMAND1执行失败,则COMMAND2不会被执行

 德摩根定律:!(A&&B)==!A||!B 

             !(A||B)==!A&&!B 

  德摩根定律的例子为:!(COMMAND1 &&COMMAND2)|| COMMAND3,解释为:COMMAND1 与COMMAND2同时执行成功才执行COMMAND3

算法或指令的实现形式:顺序执行、选择执行、循环执行

  4、异或

  比对两个操作数是否不同。如果不同,则逻辑运算结果为真,如果相同,逻辑运算结果为假   


二、Shell脚本编程

Shell脚本编程的编程即编写程序源代码。为了能够让用户在使用计算机的时候,能以非交互式的方式完成某些任务,所以我们需要把这些任务编制为一个文件,让计算机顺序读取,从而实现功能;Shell脚本编程的动态编译即调用库文件。

shell脚本是根据用户的需求解释用户问题的大量命令组合体,为纯文本文档;调用shell程序,其次调用需要的外部命令文件,命令解释器。 Shell脚本编程为过程式编程语言,解释运行,依赖于外部程序文件运行 提供了单一功能的单程接口,过程式编程逻辑的支持。

很多命令都不具备“执行幂等性”,在shell脚本中就需要使用大量的程序逻辑来判断某个目命令是否满足其运行条件,以避免在运行过程中出现严重错误

编程语言分为高级语言和低级语言,具体解释如下。

1、高级语言

(1)、根据源代码的处理方式分为:编译运行语言、解释运行语言

编译运行语言具体过程为:源代码----->编译器(汇编)-----> [连接器(完成库的链接行为)]------->可以直接执行的二进制文件

解释运行语言具体过程为:源代码------->直接启动跟源代码对应的解释器程序,由解释器边解释边执行

(2)、根据编程过程中功能的实现是调用库还是调用外部程序分为:完整编程语言、脚本编程语言

  完整编程语言具体为:利用库或编程组件进行编程

  脚本编程语言具体为:解释器编程

(3)、根据程序的编写范式分为:过程式编程语言、对象式编程语言

 过程式编程语言具体为:围绕指令(

算法)的实现设计数据和数据结构,数据为指令服务

 对象式编程语言具体为:以数据(数据结构)为中心,将数据实例化为类,围绕数据的需求来部署指令  类、属性、方法

2、低级语言:汇编语言。


Shell脚本中的代码内容有如下要求和解释:

1、首行必须是shebang,解释器路径,必须占据绝对行首;在执行时,启动相应的解释器以解释脚本内诸多的命令

例如:#!/bin/bash ;#!/bin/sh ;#!/usr/bin/python

2、在shell脚本中,除了shebang之外,以#占据绝对行首的内容,均为注释行,解释器会会忽略这样行的内容

3、解释会忽略脚本中所有的空白行

4、大量的命令和关键字(if, else, then, do, while, for……)

注意:shell脚本一旦运行,是在当前的shell中根据shebang的指示,开启一个指示器(子shell)解释执行代码内容,shell脚本的内容是在一个子shell中实现的


脚本的运行方法部分方法如下:

1、为文本文件赋予执行权限,直接运行此文件;如果在执行脚本时,只写脚本文件名不给出路径的话,必须确保PATH变量中保存的路径下,能找到该文本文件

 例如:chmod +x /PATH/TO/SCRIPT_FILE

       ~]# /PATH/TO/SCRIPT_FILE

2、直接使用解释器运行脚本,将脚本作为解释器命令的参数

 例如:bash /PATH/TO/SCRIPT_FILE




     本文转自little_ding 51CTO博客,原文链接:http://blog.51cto.com/12496428/1912843,如需转载请自行联系原作者



相关文章
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
1月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
79 1
|
2月前
|
Shell Linux
Linux shell编程学习笔记30:打造彩色的选项菜单
Linux shell编程学习笔记30:打造彩色的选项菜单
|
22天前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
45 2
6种方法打造出色的Shell脚本
|
8天前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
29 1
|
13天前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
35 2
|
13天前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
30 2
|
27天前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
47 6
|
23天前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
1月前
|
存储 缓存 分布式计算
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
这篇文章是关于数据结构与算法的学习指南,涵盖了数据结构的分类、数据结构与算法的关系、实际编程中遇到的问题以及几个经典的算法面试题。
31 0
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
下一篇
无影云桌面