Ruby 命令行单行脚本实用指南
1. 输出缓冲问题与同步解决
在处理输出时,可能会遇到缓冲问题。例如,填充一个 4,096 字节的缓冲区可能只需几秒,而填充一个 65,536 字节的缓冲区则可能需要长达两小时,这会导致在程序结束前我们看不到任何输出。为避免这个问题,可以使用同步版本的脚本。
以下是一个示例代码:
$stdout.sync = true
100.times do
"hello world".each_char do |c|
print c
sleep 0.1
end
print "\n"
end
在上述代码中,我们将 $stdout.sync 设置为 true ,这会告诉标准输出流不要进行缓冲,而是持续刷新。如果将此脚本的输入通过管道传递给 cat ,我们会看到每 0.1 秒输出一个字符。虽然脚本执行的总时间不变,但管道中的下一个程序可以立即处理输出,从而可能加快整个管道的处理时间。
2. 文本处理与脚本替代方案
在某些情况下,编写完整的脚本并非最佳选择。比如问题是临时的,我们不希望解决方案一直留存;或者问题非常简单,不值得保存为文件;又或者我们处于解决方案的初步探索阶段。在这些情况下,能够从命令行处理文本会很有优势,这样可以快速组合文本处理管道,直接解决问题或为未来更完善的解决方案奠定基础。
这些处理管道通常会使用标准的 Unix 实用工具,如 cat 、 <
超级会员免费看
订阅专栏 解锁全文
67

被折叠的 条评论
为什么被折叠?



