我正在用Java编写一个DB连接池。它只是一个类,它拥有一堆连接并给出它们。
我是否需要某种析构函数方法,以便在我的类的实例超出作用域时关闭DB连接?
编辑:这是为了学习的目的,只有。我肯定会在生产使用中使用一个可靠的、开放源码的连接池。我真的很想了解内存管理的含义。
发布于 2011-01-20 01:19:48
如果你是为了学习而尝试这样做,那么你所做的一切都是好的。下载下面提到的一个库的源代码并浏览它们的代码。这将帮助你理解他们是如何处理连接的生命周期的。
但是,如果您想将其用作生产应用程序的一部分,那么我强烈建议您使用以下内容之一
发布于 2011-01-20 01:32:35
就在我头上,说你有东西,钥匙。为您的密钥实现唯一的标识。hashCode()是一个很好的起点。创建对象时,将对象放置在WeakReference中,并将其与ReferenceQueue关联。现在使用hashCode作为Map<int, Connection>的键。当对象超出作用域时,转到ReferenceQueue检索对象,使用hashCode从Map获取Connection并关闭它。
参见关于参考资料的教程这里
发布于 2011-01-20 04:44:17
正确的方法是将连接实例封装在实现java.sql.Connection的自己的类中,然后通过池给出“连接”。您将被迫实现所有可以愉快地传递到“真实”连接的方法。除了一封()。在此方法中,您应该返回到池的连接而不关闭它。
不能仅仅让对象超出范围就将其返回到池中。您可以在finalize()中放置一些东西,然后将其返回到池中,但是这样做是危险的。Finalize()只对任何对象运行一次,因此,如果您在其中放置了一些东西来“捕获”对象并防止其被gc_‘_d_’_‘_
https://stackoverflow.com/questions/4742551
复制相似问题