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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 丁艳姣 中级黑马   /  2012-10-24 09:13  /  2172 人查看  /  7 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我对数据库不是很了解,有点小不明白为什么在数据定义的前面加using,是起到命名或者引用的意思吗
比如说using(sqlcommand cmd=conn.GreateCommand())

7 个回复

倒序浏览
使用using语句,定义一个范围,在范围结束时处理对象(释放资源)。(不过该对象必须实现了IDisposable接口)

评分

参与人数 1技术分 +1 收起 理由
王松老师 + 1

查看全部评分

回复 使用道具 举报
不加using时用dispose是相同结果?
回复 使用道具 举报
起到释放资源的作用,你不必再写con.close()了就。。。版主要是再不给加技术分,元芳,你怎么看。。。。

评分

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

查看全部评分

回复 使用道具 举报
close了还可以再open,disopse了就不能再open了,我就是在纠结这,不知道using的作用是跟哪个相同
回复 使用道具 举报
元芳已经感觉很无奈了·····
回复 使用道具 举报
我也想加分。using(),通常用在释放资源这点上。using(初始化的对象a){a能使用的有效范围}无法识别到a的范围;
一般是SQL的连接,操作使用的几个对象·以及文件流操作的几个对象会使用到using()。当然,你不用using,自己在使用完后释放掉也可以的。

评分

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

查看全部评分

回复 使用道具 举报
姐这个问题,using资源释放,不用手写con.close(),你看看当时咱们写的Sqlhelper 里面返回sqldatereader对象的那段

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