为什么生成大量随机数据的速度要慢得多?

问题描述

我想生成大量随机数。我编写了以下 bash 命令(请注意,我在此处使用 cat 用于演示目的;在我的实际用例中,我将数字通过管道传输到进程中):

for i in {1..99999999}; do echo -e "$(cat /dev/urandom | tr -dc '0-9' | fold -w 5 | head -n 1)"; done | cat

这些数字的打印速度非常低。但是,如果我生成的数量较少,则速度会快得多:

for i in {1..9999}; do echo -e "$(cat /dev/urandom | tr -dc '0-9' | fold -w 5 | head -n 1)"; done | cat

请注意,唯一的区别是 9999 而不是 99999999

这是为什么?数据是否在某处缓冲?有没有办法优化这一点,以便随机数立即通过管道/流式传输到 cat 中?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)