所谓缓冲区是sed内部的一段存储空间
G表示把缓冲内容加到处理行的末尾
h表示把当前行内容放入缓冲区
d是表示删除当前处理的行,否则默认就会打印该行内容
然后来看下面的例子:
[root@yellzone root]# seq 6
1
2
3
4
5
6
[root@yellzone root]# seq 6|sed '1!G;h;$!d'
6
5
4
3
2
1
第一行的时候
1!G 在处理第一行的时候不把缓冲内容添加到 当前处理行的末尾(因为你处理第一行的时候,缓冲还为空呢)
h 这个时候把第一行的内容(1)放到缓冲区
$!d 因为不是最后一行,所以删除,不打印出来
第二行的时候
1!G 因为是第二行,所以1!G成立,则把上一次(第一行)保存的缓冲区内容(1)放到当前行(2)的末尾,第二行变成了(21)
h 这个时候把第二行的内容(21)放到缓冲区
$!d 因为不是最后一行,所以删除,不打印出来
第三行的时候
1!G 因为是第三行,所以1!G成立,则把上一次(第二行)保存的缓冲区内容(21)放到当前行(3)的末尾,第二行变成了(321)
h 这个时候把第三行的内容(321)放到缓冲区
$!d 因为不是最后一行,所以删除,不打印出来
....
....
....
第六行的时候
1!G 因为是第六行,所以1!G成立,则把上一次(第5行)保存的缓冲区内容(54321)放到当前行(6)的末尾,第六行变成了(654321)
h 这个时候把第六行的内容(654321)放到缓冲区
$!d 因为是最后一行,所以不删除,打印出第六行内容 654321