博客
关于我
shell编程之for循环
阅读量:576 次
发布时间:2019-03-11

本文共 1713 字,大约阅读时间需要 5 分钟。

Linux shell脚本中的For循环优化技巧

在Linux shell编写脚本时,For循环是处理大量重复任务的核心工具。本文将详细介绍shell脚本中的For循环使用方法,包括带列表、不带列表、类C风格以及无限循环的实现技巧。

1. 带列表的For循环

最常见的For循环是用于遍历列表中的元素,逐一处理每个项目。语法结构如下:

for VARIABLE in (list) do    COMMANDdone

示例1:遍历特定列表

#!/bin/bashfor FRUIT in apple orange banana pear do    echo "$FRUIT is John's favorite"done

运行脚本:

# execute the scriptsh fruit.sh

输出结果:

apple is John's favoriteorange is John's favoritebanana is John's favoritepear is John's favorite

示例2:使用变量求和

#!/bin/bashsum=0for VAR in `seq 1 100` do    let "sum += VAR"doneecho "Total: $sum"

运行脚本:

sh sum.sh

输出结果:

Total: 5050

说明:seq 1 100 会生成从1到100的数字列表,循环中依次加到sum变量中。

2. 不带列表的For循环

不带列表的For循环适用于程序接受参数传递的方式。语法结构如下:

for VARIABLE in (list) do    COMMANDdone

示例如下:

#!/bin/bashsum=0for VAR do    let "sum += VAR"done

运行脚本:

sh sum.sh 2 5 6

输出结果:

Total: 13

说明:脚本后面使用空格分隔的参数传递给loop,参数会作为变量处理。

3. 类C风格的For循环

shell支持类似C语言的for循环结构,语法形式如下:

for ((expression1; expression2; expression3)) do    COMMANDdone

表达式说明:

  • expression1:初始化语句,可定义多个变量,用逗号分隔。
  • expression2:判断条件,只有条件为真时才继续循环。
  • expression3:执行循环结束之前的最后一次语句,修改变量。

示例:初始化循环变量并倒数

#!/bin/bashfor ((i=1; j=100; i++; j--)) do    echo "i=$i, j=$j"done

运行脚本:

sh c_for.sh

输出结果:

i=1, j=100i=2, j=99...i=10, j=91

说明:循环从1开始递增,j从100递减,直到i和j都超过设定范围。

4. 无限循环(Deadlock Loop)

无限循环适用于需要持续执行特定操作的任务。条件只要保持为真,循环就会无止境进行。例如:

#!/bin/bashfor ((i=0; i<1; i+=0)) do    echo "i=$i"done

运行脚本:

可以通过Ctrl+C组合键终止循环。

循环特点:

  • expression2(判断条件)必须为true,否则循环不会执行。
  • expression3 可以为变量增加操作,确保条件一直满足。

注意事项:

在使用无限循环时,建议配合其他机制(如计时器、监控条件变量)结合使用,避免造成资源耗尽或系统不响应。

实用小贴士

  • 优化循环内部语句

    • 尽量将循环内的命令放入子-shell,避免覆盖变量。
    • 使用(( ))结构以确保针对每个循环体都具有独立环境。
  • 循环变量的命名

    • 尽量避免使用共享变量名,定义不同的循环变量以防干扰。
  • 性能优化

    • 避免在循环内使用复杂命令或脚本,增加循环次数会显著影响执行时间。
    • 对于大列表,可以考虑分批处理或分页效果。
  • 通过以上方法,可以有效地在shell脚本中实现循环控制任务,从而提升工作效率。

    转载地址:http://bdtvz.baihongyu.com/

    你可能感兴趣的文章
    Oracle Spatial空间数据库建立
    查看>>
    UML— 活动图
    查看>>
    oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
    查看>>
    oracle SQLserver 函数
    查看>>
    oracle sql分组(group,根据多个内容分组)在select之后from之前 再进行select查询,复杂子查询的使用
    查看>>
    Oracle Statspack分析报告详解(一)
    查看>>
    oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
    查看>>
    Oracle Validated Configurations 安装使用 说明
    查看>>
    oracle where 条件的执行顺序分析1
    查看>>
    oracle 中的 CONCAT,substring ,MINUS 用法
    查看>>
    Oracle 中的 decode
    查看>>
    oracle 中表一对多取多方的最新的一条数据
    查看>>
    oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
    查看>>
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 修改数据库表数据提交之后进行回滚
    查看>>
    UML-总结
    查看>>
    oracle 内存参数示意图
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>
    UML- 配置图(部署图)
    查看>>