Python中with的用法

with 是 Python 中用于管理上下文资源 的关键字,主要用于确保资源的正确分配和释放(如文件、网络连接、线程锁等),避免资源泄漏或未清理的问题。其核心功能是通过上下文管理协议__enter____exit__ 方法)实现。

功能与用法

  1. 自动资源管理
    with 代码块执行前,会调用上下文管理器的 __enter__ 方法初始化资源;代码块结束后(无论是否发生异常),自动调用 __exit__ 释放资源。
  2. 异常处理
    __exit__ 方法会处理异常,可选择是否抑制异常(通过返回值控制)。这使得资源清理更可靠,无需手动写 try...finally

常见场景示例

1. 文件操作(经典用法)

csharp 复制代码
python
with open("data.txt", "r") as file:
    content = file.read()
# 退出 with 块后,文件自动关闭,无需手动调用 file.close()

2. 线程锁

csharp 复制代码
python
import threading

lock = threading.Lock()

with lock:
    # 临界区代码(自动加锁/释放锁)
    print("Thread-safe operation")

3. 自定义上下文管理器

通过实现 __enter____exit__ 方法定义自己的资源管理逻辑:

python 复制代码
python
class CustomContext:
    def __enter__(self):
        print("分配资源")
        return self  # 返回的资源对象会被 as 接收
    
    def __exit__(self, exc_type, exc_val, exc_tb):
        print("释放资源")

with CustomContext() as ctx:
    print("执行操作")

使用 contextlib 简化

对于简单场景,可用 contextlib.contextmanager 装饰器快速创建上下文管理器:

python 复制代码
python
from contextlib import contextmanager

@contextmanager
def timer():
    start = time.time()
    yield  # 此处为 with 块内的代码执行位置
    print(f"耗时: {time.time() - start} 秒")

with timer():
    time.sleep(2)  # 输出:耗时: 2.0 秒

核心优势

  • 代码简洁性 :避免冗余的 try...finally 或手动关闭操作。
  • 安全性:确保资源始终被释放,即使代码块中发生异常。
  • 可读性:明确标识资源的作用域。

适用于所有实现了上下文管理协议的对象(如文件、数据库连接、临时目录等)。

相关推荐
冷雨夜中漫步8 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再8 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
喵手10 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_9449347310 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy10 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
肖永威12 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ12 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha12 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy12 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法