Golang是一种编程语言,它以其高效性和并发性而闻名。然而,关于Golang的加密和线程安全性一直是开发者们关注的重点。在这篇文章中,php小编香蕉将分享关于Golang加密和Golang线程安全性的一些观点和建议。我们将探讨Golang在加密方面的特性,以及如何确保线程安全性,以帮助开发者更好地理解和应用Golang。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和指导。
问题内容
math/rand.rand 的源指出 read
不是线程安全的(共享源时)。加密/兰特怎么样?源代码指出它使用 getrandom(2)
或 /dev/urandom
,但尚不清楚并发调用会发生什么。
更新:评论有助于澄清区别
crypto/rand.Reader.Read(b []byte)
crypto/rand.Read(b []byte)
线程安全:
- 并发调用
read
会panic吗? - 并发调用时会保持随机序列吗?或者可以向并发调用者提供重复的内容吗?
解决方法
-
rand.Reader
来自crypto/rand
必须对于并发访问是安全的,因为它被定义为“加密安全随机数生成器的全局共享实例”。无法在包之间同步其使用。 -
rand.Read
来自crypto/rand
是安全的,因为rand.Reader
是安全,并且它不会访问任何其他共享状态。
以上就是Golang 加密/兰德线程安全吗?的详细内容,更多请关注编程网其它相关文章!