博客
关于我
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/

    你可能感兴趣的文章
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty工作笔记0085---TCP粘包拆包内容梳理
    查看>>
    Netty常用组件一
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty心跳检测机制
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架内的宝藏:ByteBuf
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—3.Reactor线程模型三
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—5.Pipeline和Handler二
    查看>>
    Netty源码—6.ByteBuf原理一
    查看>>