在Python中如果对象定义了__del__方法的话,在对象的引用记数为0时会自动调用__del__方法(很象c++中的析构函数),但如果A对象引用B对象,B对象又引用A对象,就形成循环引用,此时A,B对象引用次数都为1。python就无法正常调用__del__方法,原计划在__del__方法里释放的资源自然也就无法释放。

一个连接池拥有多个连接,而每个连接又拥有这个连接池的实例(一个叫pool的属性)。这样就产生了刚刚说的哪个问题。我想到的办法就是在每次从池中获取连接的时候将连接的pool设置为当前实例,然后在归还这个连接的时候再将其设置为None,并且要在这个连接对象的__del__方法中将pool属性设置为None。具体看代码吧。(目前只实现了SQLite3的)

'''

Created on 2009-4-17

@author: phyeas

'''

import time

from queue import Queue

class PoolException(Exception):

pass

class Pool(object):

'''一个数据库连接池'''

def __init__(self, maxActive=5, maxWait=None, init_size=0, db_type="SQLite3", **config):

self.__freeConns = Queue(maxActive)

self.maxWait = maxWait

self.db_type = db_type

self.config = config

if init_size > maxActive:

init_size = maxActive

for i in range(init_size):

self.free(self._create_conn())

def __del__(self):

print("__del__ Pool..")

self.release()

def release(self):

'''释放资源,关闭池中的所有连接'''

print("release Pool..")

while self.__freeConns and not self.__freeConns.empty():

con = self.get()

con.release()

self.__freeConns = None

def _create_conn(self):

'''创建连接 '''

if self.db_type in dbcs:

return dbcs[self.db_type](**self.config);

def get(self, timeout=None):

'''获取一个连接

@param timeout:超时时间

'''

if timeout is None:

timeout = self.maxWait

conn = None

if self.__freeConns.empty():#如果容器是空的,直接创建一个连接

conn = self._create_conn()

else:

conn = self.__freeConns.get(timeout=timeout)

conn.pool = self

return conn

def free(self, conn):

'''将一个连接放回池中

@param conn: 连接对象

'''

conn.pool = None

if(self.__freeConns.full()):#如果当前连接池已满,直接关闭连接

conn.release()

return

self.__freeConns.put_nowait(conn)

from abc import ABCMeta, abstractmethod

class PoolingConnection(object, metaclass=ABCMeta):

def __init__(self, **config):

self.conn = None

self.config = config

self.pool = None

def __del__(self):

self.release()

def __enter__(self):

pass

def __exit__(self, exc_type, exc_value, traceback):

self.close()

def release(self):

print("release PoolingConnection..")

if(self.conn is not None):

self.conn.close()

self.conn = None

self.pool = None

def close(self):

if self.pool is None:

raise PoolException("连接已关闭")

self.pool.free(self)

def __getattr__(self, val):

if self.conn is None and self.pool is not None:

self.conn = self._create_conn(**self.config)

if self.conn is None:

raise PoolException("无法创建数据库连接 或连接已关闭")

return getattr(self.conn, val)

@abstractmethod

def _create_conn(self, **config):

pass

class SQLit3PoolConnection(PoolingConnection):

def _create_conn(self, **config):

import sqlite3

return sqlite3.connect(**config)

dbcs = {"SQLite3":SQLit3PoolConnection}

pool = Pool(database="F:\\test\\a")

def test():

conn = pool.get()

with conn:

for a in conn.execute("SELECT * FROM A"):

print(a)

if __name__ == "__main__":

test()

以上代码在python3.0中测试通过……

python循环顶帖_设计Python数据库连接池1-对象的循环引用问题相关推荐

  1. Python 是怎么火起来的? 转载 2018年01月12日 00:00:00 133 图:Python 之父 Guido 正在设计 Python 语言,结果家里突然潜入一条大蟒蛇,一番激烈斗争,大

    Python 是怎么火起来的? 转载 2018年01月12日 00:00:00 133 图:Python 之父 Guido 正在设计 Python 语言,结果家里突然潜入一条大蟒蛇,一番激烈斗争,大蟒 ...

  2. Python 豆瓣顶帖

    ?? 由于在豆瓣发了个租房帖子,发现很快就被其他的帖子淹没,但是手动顶帖实在太累,?,所以想通过自动顶帖的方式来解放双手! 评论请求分析 通过Chrome network 分析 add_comment ...

  3. python课程报告论文_高中Python校本课程的设计与实施

    43 MAY 2019 NO.10 高中Python校本课程的设计与实施 郑兴航 江苏省锡山高级中学 2018年1月 , 新版高中信息技术 课程标准正式颁布 , 对照2003版, 新标准在课程目 标和 ...

  4. python双重for循环怎么理解_理解 Python 的 for 循环

    Python部落(python.freelycode.com)组织翻译,禁止转载,欢迎转发. 在本篇博客中,我们将讨论 Python 中 for 循环的原理. 我们将从一组基本例子和它的语法开始,还将 ...

  5. python循环修改列表_关于python:如何在for循环中修改列表项?

    现在,我知道在迭代循环中修改列表是不安全的. 但是,假设我有一个字符串列表,并且我想自己剥离字符串. 替换可变值是否算作修改? 字符串不是可变值. @ user470379:列表的元素是否可变与在循环 ...

  6. python 循环播放音乐_基于python实现音乐播放器代码实例

    核心播放模块(pygame内核) import time import pygame import easygui as gui file = r'D:\CloudMusic\G.E.M.邓紫棋,艾热 ...

  7. python测试抽奖脚本_使用 Python 写一个简易的抽奖程序

    不知道有多少人是被这个头图骗进来的:) 事情的起因是这样的,上周有同学问小编,看着小编的示例代码敲代码,感觉自己也会写了,如果不看的话,七七八八可能也写的出来,但是一旦自己独立写一段程序,感觉到无从下 ...

  8. 编程游戏python我的世界_乐学Python编程-做个游戏很简单

    1.进入Python 编程世界/ 2 1.1 启动Python 编程环境/ 5 1.2 Python 之禅/ 9 1.3 送你几朵玫瑰花--运行Python 程序/ 16 1.4 Python 的由来 ...

  9. python 预编译加速_让Python代码运行更快的最佳方式

    Python因其强大.灵活且易于使用等特性,而赢得了声誉.这些优点使其在各种各样的应用程序.工作流程和领域中得到了广泛应用.但是就语言的设计,也就是它天然的解释能力还有它的运行时的动态性而言,Pyth ...

最新文章

  1. 参数估计_数据分析|统计之一个总体参数估计(附代码)
  2. JavaWeb显示器
  3. 未封装的扩展程序是什么意思_Android漏洞挖掘第三期:客户端完整性未校验
  4. 交换系统接媒体服务器,基于软交换的媒体服务器的设计与实现
  5. Java 8发布一年后,IDE和编译器尚未完全就绪
  6. hadoop集群-格式化namenode节点后,从节点的datanode不能启动,或者是datanode启动到主节点上。
  7. C语言提前结束for循环,[新人求指教]51C语言编程可否用中断令循环结束提早结束...
  8. 用户只有一部手机,怎么保护私钥—— mixin如何实现资产安全
  9. 有刷/无刷动力电调与马达知识
  10. 企业名录114_1.36
  11. python爬虫-国家企业_国家企业信用公示系统的爬取
  12. 织梦首页php打开慢,DEDECMS网站打开速度慢解决方法
  13. 考研要求过英语四六级!这些大学有明确规定!
  14. excel 单元格显示公式_如何在单元格中显示公式并在Excel 2013中完全隐藏公式
  15. python用来占位的关键字_python-study/Readme.md at master · wchhuangya/python-study · GitHub
  16. 【1016】从产品创意到产品概念
  17. 微信,找回好友、群聊用户撤回的消息
  18. 《冰封王座》世界魔兽界十大叱咤风云人物
  19. 看美剧学英语 看一部大片胜过在美生活十天
  20. 生化危机8Switch Pro手柄按键提示补丁MOD

热门文章

  1. java audiorecord_Android 录音实现(AudioRecord)
  2. group by很多字段是不是会很慢_女生回复我总很慢,怎么办?
  3. thinkphp5.1 php7,空白目录 · 细数ThinkPHP5.1.7版本新特性 · 看云
  4. 前端面试每日 3+1(每日三问)
  5. Cs231n课堂内容记录-Lecture 5 卷积神经网络介绍
  6. 树状数组的建树 单点修改 单点查询 区间修改 区间查询
  7. python天蝎座-day1笔记
  8. 内容拾遗之字符串与数据结构
  9. IC设计前端几本经典书籍
  10. linux与windows间共享文件夹 FileZilla树莓派文件传输