随笔 - 407  文章 - 51  评论 - 2  阅读 - 13万

日志错位读写的问题

在对象销毁的时候需要记得销毁句柄:

复制代码
class NgLogger:
    def __init__(self, module, file_name):
        self.logger = logging.getLogger(module)
        self.logger.setLevel(logging.DEBUG)
        self._fh = logging.FileHandler(file_name)
        self._fh.setLevel(logging.DEBUG)
        # create console handler with a higher log level
        self._ch = logging.StreamHandler()
        self._ch.setLevel(logging.DEBUG)
        # create formatter and add it to the handlers
        formatter = logging.Formatter('%(levelname)s %(asctime)s [%(filename)s:%(lineno)d] %(message)s')
        self._fh.setFormatter(formatter)
        self._ch.setFormatter(formatter)
        # add the handlers to the logger
        self.logger.addHandler(self._fh)
        self.logger.addHandler(self._ch)

    def __del__(self):
        self.logger.info('write log finished')
        self.logger.removeHandler(self._fh)
        self.logger.removeHandler(self._ch)
复制代码

不确认对象是否销毁可以del 对象

 

posted on   kid;)  阅读(5)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2022-11-28 车辆检查
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示