while read line:是一次性将文件信息读入并赋值给变量line ,
while中使用重定向机制,文件中的所有信息都被读入并重定向给了整个while 语句中的line 变量。
for:是每次读取文件中一个以空格为分割符的字符串。
如下示例脚本:
#/bin/bash IPS="10.1.1.10 3001 10.1.1.10 3003 10.1.1.11 3001 10.1.1.11 3002 10.1.1.11 3004 10.1.1.11 3005 10.1.1.13 3002 10.1.1.13 3003 10.1.1.13 3004 10.1.1.14 3002" echo "====while test ====" i=0 echo $IPS | while read line do echo $(($i+1)) echo $line done echo "====for test ====" n=0 for ip in $IPS ; do n=$(($n+1)) echo $ip echo $n done
输出结果如下:
====while test ==== 1 10.1.1.10 3001 10.1.1.10 3003 10.1.1.11 3001 10.1.1.11 3002 10.1.1.11 3004 10.1.1.11 3005 10.1.1.13 3002 10.1.1.13 3003 10.1.1.13 3004 10.1.1.14 3002 ====for test ==== 10.1.1.10 1 3001 2 10.1.1.10 3 3003 4 10.1.1.11 5 3001 6 10.1.1.11 ....
当文件中有多行文字,在while循环中再一次调用read语句,就会读取到下一条记录。而$line中的最后一行已经读完,无法获取下一行记录,从而退出 while循环。
若使用while循环,想每次读取其中1行内容到变量$line,则可以使用以下方法:
#!/system/bin/sh busybox cat /data/data/1.txt | while read LINE do adb shell gsr -m -p /data/data/$LINE 10000 done
while read line do echo $line done<A <A写在最后相当于给整个while do 语句加了一个约束条件,读取文件A里每行至文件尾结束
while read line<A do echo $line done <A写在前面,整个while do语句就没有约束条件, 因为 read line<A这个始终为真 表示 不停地 读取A中的第一行,赋值给参数line,然后打印参数line的值.