首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java -内存管理/ DB连接问题

Java -内存管理/ DB连接问题
EN

Stack Overflow用户
提问于 2011-01-20 01:14:57
回答 3查看 286关注 0票数 0

我正在用Java编写一个DB连接池。它只是一个类,它拥有一堆连接并给出它们。

我是否需要某种析构函数方法,以便在我的类的实例超出作用域时关闭DB连接?

编辑:这是为了学习的目的,只有。我肯定会在生产使用中使用一个可靠的、开放源码的连接池。我真的很想了解内存管理的含义。

EN

回答 3

Stack Overflow用户

发布于 2011-01-20 01:19:48

如果你是为了学习而尝试这样做,那么你所做的一切都是好的。下载下面提到的一个库的源代码并浏览它们的代码。这将帮助你理解他们是如何处理连接的生命周期的。

但是,如果您想将其用作生产应用程序的一部分,那么我强烈建议您使用以下内容之一

  1. BoneCP
  2. c3p0
票数 2
EN

Stack Overflow用户

发布于 2011-01-20 01:32:35

就在我头上,说你有东西,钥匙。为您的密钥实现唯一的标识。hashCode()是一个很好的起点。创建对象时,将对象放置在WeakReference中,并将其与ReferenceQueue关联。现在使用hashCode作为Map<int, Connection>的键。当对象超出作用域时,转到ReferenceQueue检索对象,使用hashCodeMap获取Connection并关闭它。

参见关于参考资料的教程这里

票数 2
EN

Stack Overflow用户

发布于 2011-01-20 04:44:17

正确的方法是将连接实例封装在实现java.sql.Connection的自己的类中,然后通过池给出“连接”。您将被迫实现所有可以愉快地传递到“真实”连接的方法。除了一封()。在此方法中,您应该返回到池的连接而不关闭它。

不能仅仅让对象超出范围就将其返回到池中。您可以在finalize()中放置一些东西,然后将其返回到池中,但是这样做是危险的。Finalize()只对任何对象运行一次,因此,如果您在其中放置了一些东西来“捕获”对象并防止其被gc_‘_d_’_‘_

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4742551

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档