我是一名 java 开发人员并开始学习 python 语言,最近我遇到了使用异步 greenlets 的 Python Gevent 库。有人可以解释一下,同步、死锁、活锁如何在 Python 中使用 Gevent 工作/避免。
- 在 Java 线程中,我们有同步块,它可以防止上述问题
我是一名 java 开发人员并开始学习 python 语言,最近我遇到了使用异步 greenlets 的 Python Gevent 库。有人可以解释一下,同步、死锁、活锁如何在 Python 中使用 Gevent 工作/避免。
使用 gevent 编写并发应用程序不同于使用多线程或多进程的应用程序。它允许您使用同步逻辑编写并发应用程序,并且一次只能运行一个 greenlet。
如果你创建了很多greenlet,它们应该访问同一个资源,但它们没有合作关系,那么你不必使用锁来控制它们访问共享资源,因为一次只能运行一个greenlet。直到greenlet遇到一些可以将执行交给hub greenlet的操作,它才会一直运行直到它返回。
如果你创建的greenlets有合作关系,你可以像在Java中那样使用gevent提供的锁。
以下是一些可能对您有帮助的资源: