在类Unix操作系统上,如果文件仍处于打开状态,则可以删除文件。文件名将不再存在,但数据本身保持不变,任何具有开放句柄(包括bash)的程序都可以继续使用该句柄读取(甚至写入)。只有当最后一个程序关闭它的句柄时,文件才真正被删除。
因此,从某种意义上说,是的,一个shell脚本可以删除它自己,但它不会删除真正的,直到该脚本执行完成为止。
请注意,如果您将重写为而不是将其删除,则会得到不同的结果。壳可能(并且确实)使用缓冲来避免一次读取一个字节,但缓冲区的大小是有限的。如果文件内容超出了shell已经读入内存的内容,它将看到新的内容。如果您检查系统的缓冲区大小,您可以创建一个简单的示例。在我的系统上,它恰好是8 KiB。因此,包含
echo line 1
>test.sh
# (8167 random characters)
echo line 4
一个shell脚本,所以数据的第二块是“cho line 4”,我的系统上,输出
$ bash test.sh
line 1
test.sh: line 4: e: command not found
因为e已经被阅读,和外壳EOF时遇到试图读取该行的其余部分。
更新:rici显示,用覆盖文件的不同示例,新写入的内容得到使用。返工是:
script="`tr 12 21
env echo "$script" >test.sh
echo toggle: 1
第二行有意不使用bash的内置echo命令,因为有时不会引起庆典重读剧本,每次的意见,但正是当它与我不清楚。当它到达第三行时,bash输出新写入的切换值。这个和我之前的例子之间的区别似乎是,在这里,bash可以在第三行找到当前位置,而在我之前的例子中,这是不可能的,因为该位置不再存在,因为文件是空。