前端之家收集整理的这篇文章主要介绍了
c – 为什么从/ dev / random读取几乎总是阻塞?,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用内核2.6.38-12-generic的kubuntu
我想在程序开始时从/ dev / random中读取16个随机数.
但是,它会在相对较短的时间后阻塞.
/ dev / random缓冲区需要多长时间才能填充?为什么需要这么长时间来填补.
我正在使用它作为一个uuid生成器,其他随机源添加到种子
我的mersenne twister.至关重要的是,我没有重复或重复的种子.
如果我改为/ dev / urandom,它可以正常工作.关于在/ dev / urandom上使用/ dev / random的任何视图.
最佳答案
你真的不应该使用/ dev / random.没有已知的情况,/ dev / random优于/ dev / urandom,并且缺点非常明显.
区别在于/ dev / urandom提供“仅仅”加密安全的随机数,而/ dev / random提供真正的随机数(至少,这是我们所相信的).但是,没有已知的情况,这种差异很重要,并且没有已知的测试可以区分“真正的”随机性和仅仅是密码安全的随机性.
我经常开玩笑说/ dev / urandom提供水和/ dev / random提供圣水.