Python中的琐碎上下文管理器

sds

我的资源可以是R1需要锁定的类型R2,也可以是不需要锁定的类型

class MyClass(object):   # broken
    def __init__ (self, ...):
        if ...:
            self.resource = R1(...)
            self.lock = threading.Lock()
        else:
            self.resource = R2(...)
            self.lock = None

    def foo(self):   # there are many locking methods
        with self.lock:
            operate(self.resource)

如果self.lock是则上述显然失败None

我的选择是:

  1. if

    def foo(self):
        if self.lock:
            with self.lock:
                operate(self.resource)
        else:
            operate(self.resource)
    
    • 缺点:太冗长
    • 优点:不会产生不必要的 threading.Lock
  2. 始终设置self.lockthreading.Lock

    • 优点:代码简化
    • 缺点:with self.lock似乎比较昂贵(与磁盘I / O相当!)
  3. 定义一个简单的锁类:

    class TrivialLock(object):
        def __enter__(self): pass
        def __exit__(self, _a, _b, _c): pass
        def acquire(self): pass
        def release(self): pass
    

    并使用它代替Nonefor R2

    • 专家:简单代码
    • 缺点:我必须定义 TrivialLock

问题

  1. 社区首选哪种方法?
  2. 不管(1)是什么,实际上有人定义了TrivialLock吗?(我实际上希望标准库中会出现类似的东西……)
  3. 我的观察结果是锁定成本与write符合预期的成本相当吗?
切普纳

我会定义TrivialLock但是,由于您只需要上下文管理器而不是锁,因此它甚至更无关紧要。

class TrivialLock(object):
    def __enter__(self):
        pass
    def __exit__(*args):
        pass

您可以使用contextlib以下命令使它变得更简单

import contextlib

@contextlib.contextmanager
def TrivialLock():
    yield

self.lock = TrivialLock()

由于yield可以是表达式,因此可以定义TrivalLock内联:

self.lock = contextlib.contextmanager(lambda: (yield))()

注意括号;lambda: yield是无效的。但是,生成器表达式(yield)使它成为一次性使用的上下文管理器。如果您尝试在第二条with语句中使用相同的值,则会收到Runtime错误消息,因为generator已用尽。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

TOP 榜单

  1. 1

    来自Microsoft Office加载项taskpane.js的MySQL驱动程序模块的空引用

  2. 2

    使用AWS Cognito和React的仅限Facebook / Google的登录名(无用户名/密码)

  3. 3

    创建Windows Phone 8应用并将其连接到数据库的最佳方法(最好是SQL Server)

  4. 4

    为什么Java中的System.out.println()打印到控制台?

  5. 5

    卷曲函数无法解析来自bash中变量的代理

  6. 6

    是什么在Android的consumer-rules.pro和proguard-rules.pro之间的区别?

  7. 7

    设置与Apache POI Excel表散点图标记图标的颜色

  8. 8

    将Qt Pyside2与asyncio await语法一起使用?

  9. 9

    崇高的文字+蟒蛇的蟒蛇

  10. 10

    任务':app:minifyReleaseWithR8'.java.lang.NullPointerException的执行失败(无错误消息)

  11. 11

    OpenJDK的和AdoptOpenJDK的区别

  12. 12

    大型数据集缓存到Spark内存中时,“超出了GC开销限制”(通过sparklyr和RStudio)

  13. 13

    “执行测试CMAKE_HAVE_LIBC_PTHREAD”失败实际上是什么意思?

  14. 14

    使用Core 2.2中的Identity,如何在关闭浏览器15分钟后保持会话活动?

  15. 15

    React中的ForwardRefExoticComponent和ForwardRefRenderFunction有什么区别?

  16. 16

    猫鼬查找结果,然后将字段替换为findOne

  17. 17

    如何降级Google Colab的Torch版本

  18. 18

    Keras提前停止回调错误,val_loss指标不可用

  19. 19

    如何避免VSCode中的“导入路径不能以.ts扩展名结尾”错误?

  20. 20

    Nuxt.JS:如何在页面中获取路由URL参数

  21. 21

    是否有为什么会AccessibilityManager.sInstance导致内存泄漏的一个原因?

热门标签

归档