首页 >后端开发 >Golang >Golang 加密/兰德线程安全吗?

Golang 加密/兰德线程安全吗?

王林
王林转载
2024-02-09 12:45:081011浏览

Golang 加密/兰德线程安全吗?

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)

线程安全:

  1. 并发调用read会panic吗?
  2. 并发调用时会保持随机序列吗?或者可以向并发调用者提供重复的内容吗?

解决方法

  1. rand.Reader 来自 crypto/rand 必须对于并发访问是安全的,因为它被定义为“加密安全随机数生成器的全局共享实例”。无法在包之间同步其使用。
  2. rand.Read 来自 crypto/rand 是安全的,因为 rand.Reader 是安全,并且它不会访问任何其他共享状态。

以上是Golang 加密/兰德线程安全吗?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除