Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

29 linhas
915B

  1. import time
  2. class ExpiredDict(dict):
  3. def __init__(self, expires_in_seconds):
  4. super().__init__()
  5. self.expires_in_seconds = expires_in_seconds
  6. def __getitem__(self, key):
  7. value, expiry_time = super().__getitem__(key)
  8. # 如果元素已过期,则从字典中删除该元素并抛出 KeyError 异常
  9. if time.monotonic() > expiry_time:
  10. del self[key]
  11. raise KeyError("expired {}".format(key))
  12. return value
  13. def __setitem__(self, key, value):
  14. # 如果元素已存在,则不需要重新计算过期时间
  15. if key in self:
  16. super().__setitem__(key, (value, self[key][1]))
  17. else:
  18. super().__setitem__(key, (value, time.monotonic() + self.expires_in_seconds))
  19. def get(self, key, default=None):
  20. try:
  21. return self[key]
  22. except KeyError:
  23. return default