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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘煜 中级黑马   /  2012-7-15 14:05  /  2102 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

C#中Dispose和Close的有什么区别?使用的时候需要注意哪些问题?

评分

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

查看全部评分

5 个回复

倒序浏览
Dispose是销毁 Close是关闭 销毁后是不能再次打开 但关闭后可以打开。 Dispose用于实现实现这个接口的类 例如Sqlconnection Sqlcommand 等。

评分

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

查看全部评分

回复 使用道具 举报
最常见例子就是 在用DataReader执行数据库的时候,不能用using (sqlconnection con=new sqlconnection()){using(sqlcommand cmd=new sqlcommand(sql,con))}新建数据库连接,要手动 用con.open(),con.close()开关连接数据库,因为USING 在执行完后自带 dispose()资源释放;而datareader 必须始终保持连接的情况下才能使用。

评分

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

查看全部评分

回复 使用道具 举报
Close()被设计成public的,并且在Close()里面call被隐藏的Dispose(); Dispose()去call另一个virtual的Dispose(bool)函数。所以如果你从这个class继承,你就必须实现Dispose (bool)方法。

评分

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

查看全部评分

回复 使用道具 举报
1,Dispose了,就必须再Create一次;
2,而Close( )后,还可以再Open( );
3,而Dispose后,对象都不存在了,就不能Open( ) 了;
4,Dispose是对于对象自身而言的,Close是对于连接数据库而言的。

评分

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

查看全部评分

回复 使用道具 举报
connection.close()是暂时关闭,connection.dispose()是销毁对象。

评分

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

查看全部评分

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