Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103563701
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-04-22 13:26:24

作者: dvorss  出自:
在linux下,有个tac命令可将文本文件的文本行倒序排列输出,solaris下没有这种命令。

得到专家指点,有下列方法可用:

1. 命令方法:
nl filename | sort -nr | cut -f2

这个方法很unix风格,使用多命令组合完成某种功能是典型的unix特点。

2. AWK方法:
awk '{line[NR]=$0}END{for(i=NR;i>0;i--)print line}' filename

这个利用了AWK的数组功能。

3. PERL方法:
perl -e 'print reverse <>' filename

除非你熟悉PERL。

4. SED方法
sed '1!G;h;$!d' filename

这个操作很经典,如果你能看懂这行命令中的sed函数的意义,那对sed就有基本的了解了。

5. VI方法
vi指令 :g/^/m0

这个方法没有想到,真是简便实用。

6. shell方法
#!/bin/bash

revread() {
local line
read line || return 0
revread
echo $line
}

revread
利用了shell编程中的函数递归。

大家有没有想过,如果文本行非常多,递归层次也将非常多,那么这个脚本会导致什么效果?

试过了才知道。与C程序不同,shell脚本的递归层次增加,不会导致所谓的“堆栈溢出”,但不断增加该shell的内存占用量,如果文本行足够多,可能会耗尽系统可用内存(在系统允许的情况下)。

我们使用递归时都知道,递归层次应得到有效控制,不能无限增加。这不仅是一个资源消耗问题,也是个运行效率问题。递归方法一般只用于递归层次非常有限,且代码用递归方法表示时逻辑更清晰的场合。

所以不推荐使用这种方法,这个方法的主要目的是用来演示shell函数递归。
阅读(629) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~