A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 李宏利 中级黑马   /  2012-7-27 14:17  /  1729 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

Close:关闭以后还能打开。
Dispose:直接销毁,不能再次使用。
using::在出了作用域以后调用Dispose。
但:SqlConnection,FileStream 等的Dispose 内部都会做这样的判断:判断有没有close 如果没有Close就先Close再 Dispose。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

3 个回复

正序浏览
clo se()关闭后可以通过open()重新打开连接。而dispose()是直接销毁连接,防止多个连接占用资源,

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
conn.close()是关闭数据库连接的,关闭连接后还能再次连接,conn.dispose()是释放数据库所占的内存,不能重新连接数据库

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
1,FileStream的对象如果不在后面的代码中使用,不用close直接Dispose即可,Dispose隐含close;
2,数据连接对象推荐使用using代码块自动释放以防止中途出现异常。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马