C#.net中释放资源的两种方式

在java中我们如果用到了流或者建立了某个连接,都会在最后调用close方法,然后自己手动设置成null,或者不设置成null,垃圾处理器也会自动将其设置成null,而C#中却提供了两种释放资源的方法

使用using

在C#中使用using,当using执行完成的时候,会自动调用dispose方法,也就是释放资源

    using(SqlConnection con = new SqlConnection(connData)){
        //其他代码...
    }

使用try_catch_finally

事实上,using就相当于try_finally,而这里只是对了个catch而已,使用这个的好处可想而知,例如在使用事物的时候,在catch中回滚,而使用using就不行了

SqlConnection conn = null;
MysqlTransation tran = null;
try{
    conn = new SqlConnetion(connData);
    con.Open();//打开连接
    tran = conn.BeginConnsaction();
    //...省略其他语句
    tran.commit();
}catch{
        tran.rollback();//事物回滚
}finally{
    //..其他一些关闭操作
    tran.dispose();
    conn.close()
    conn.dispose();
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值