using (SqlConnection cn = new SqlConnection(cnStr)) 与 SqlConnection cn = new SqlConnection(cnStr)的区别

北极星6666 2008-12-17 11:06:49
using (SqlConnection cn = new SqlConnection(cnStr)) 与 SqlConnection cn = new SqlConnection(cnStr)的区别
...全文
412 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
nikolas 2008-12-17
  • 打赏
  • 举报
回复
先Close();再Dispose();
单单using
还没Close()呢
dd__dd 2008-12-17
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 jiang_jiajia10 的回复:]
using (SqlConnection cn = new SqlConnection(cnStr))
使用后自动释放不用再
cn.Open();
cn.Close();


SqlConnection cn = new SqlConnection(cnStr)
需要
cn.Open();
cn.Close();
[/Quote]
就是这个区别
Robin 2008-12-17
  • 打赏
  • 举报
回复
. using指令。using + 命名空间名字,这样可以在程序中直接用命令空间中的类型,而不必指定类型的详细命名空间,类似于Java的import,这个功能也是最常用的,几乎每个cs的程序都会用到。
例如:using System; 一般都会出现在*.cs中。
2.using别名。using + 别名 = 包括详细命名空间信息的具体的类型。
这种做法有个好处就是当同一个cs引用了两个不同的命名空间,但两个命名空间都包括了一个相同名字的类型的时候。当需要用到这个类型的时候,就每个地方都要用详细命名空间的办法来区分这些相同名字的类型。而用别名的方法会更简洁,用到哪个类就给哪个类做别名声明就可以了。注意:并不是说两个名字重复,给其中一个用了别名,另外一个就不需要用别名了,如果两个都要使用,则两个都需要用using来定义别名的。
例如:
using System;
using aClass = NameSpace1.MyClass;
using bClass = NameSpace2.MyClass;

namespace NameSpace1
{
public class MyClass
{
public override string ToString()
{
return "You are in NameSpace1.MyClass";
}
}
}

namespace NameSpace2
{
class MyClass
{
public override string ToString()
{
return "You are in NameSpace2.MyClass";
}
}
}

namespace testUsing
{
using NameSpace1;
using NameSpace2;
/**//// <summary>
/// Class1 的摘要说明。
/// </summary>
class Class1
{
/**//// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main(string[] args)
{
//
// TODO: 在此处添加代码以启动应用程序
//

aClass my1 = new aClass();
Console.WriteLine(my1);
bClass my2 = new bClass();
Console.WriteLine(my2);
Console.WriteLine("Press any key");
Console.Read();
}
}
}

3.using语句,定义一个范围,在范围结束时处理对象。
场景:
当在某个代码段中使用了类的实例,而希望无论因为什么原因,只要离开了这个代码段就自动调用这个类实例的Dispose。要达到这样的目的,用try...catch来捕捉异常也是可以的,但用using也很方便。
例如:
using (Class1 cls1 = new Class1(), cls2 = new Class1())
{
// the code using cls1, cls2


} // call the Dispose on cls1 and cls2

这里触发cls1和cls2的Dispose条件是到达using语句末尾或者中途引发了异常并且控制离开了语句块。
本文标签:

精彩尽在异度音乐网

本文最近访客查看最近位访客收起
上一篇|下一篇|返回日志列表
che2piaopiao 2008-12-17
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 jiang_jiajia10 的回复:]
using (SqlConnection cn = new SqlConnection(cnStr))
使用后自动释放不用再
cn.Open();
cn.Close();


SqlConnection cn = new SqlConnection(cnStr)
需要
cn.Open();
cn.Close();
[/Quote]

正解
claymore1114 2008-12-17
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 jiang_jiajia10 的回复:]
using (SqlConnection cn = new SqlConnection(cnStr))
使用后自动释放不用再
cn.Open();
cn.Close();


SqlConnection cn = new SqlConnection(cnStr)
需要
cn.Open();
cn.Close();
[/Quote]
正解
CosmologyNet 2008-12-17
  • 打赏
  • 举报
回复
using (SqlConnection cn = new SqlConnection(cnStr))
{
//do something
}
等同于
SqlConnection cn = new SqlConnection(cnStr);
//do something
cn.Dispose();
  • 打赏
  • 举报
回复
还不知道呢
HDNGO 2008-12-17
  • 打赏
  • 举报
回复
前一个可以自动释放~
jiang_jiajia10 2008-12-17
  • 打赏
  • 举报
回复
using (SqlConnection cn = new SqlConnection(cnStr))
使用后自动释放不用再
cn.Open();
cn.Close();


SqlConnection cn = new SqlConnection(cnStr)
需要
cn.Open();
cn.Close();

62,268

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧