标签:编译器 自动生成 string 奇葩 tle href stat 技术分享 比较
因为之前是学 Java 的,在连接数据库或者进行文件读写操作时很自然的就使用了 try…catch…finally…,在 C# 中这样写也肯定可以但是还有一种更优雅的写法(我看到别人这样说),那就是使用 using 关键字。
在使用各种流或者连接时【文件读写流,数据库连接等等】,在使用完毕后,需要关闭流和连接,(这里不讨论数据库连接需要归还到池子)
之前的代码是这样的:
public void Test1() { SqlConnection conn = null; SqlDataReader reader = null; try { string strConn = ConfigurationManager.ConnectionStrings["strConn"].ToString(); conn = new SqlConnection(strConn); conn.Open(); SqlCommand cmd = conn.CreateCommand(); cmd.CommandText = "XXXXXXXXX"; reader = cmd.ExecuteReader(); //一些操作 } catch (Exception e) { Console.WriteLine("出错啦!!"); } finally { if (conn != null) { conn.Close(); conn.Dispose(); } if (reader != null) { reader.Dispose(); } } }
使用了 using 关键字之后是这样的:
public void Test2() { string strConn = ConfigurationManager.ConnectionStrings["strConn"].ToString(); using (SqlConnection conn = new SqlConnection(strConn)) { using (SqlCommand cmd = conn.CreateCommand()) { cmd.CommandText = "XXXXXXXXXX"; using (SqlDataReader reader = cmd.ExecuteReader()) { //一些操作 } } } }关于 using 关键字,有必要弄清楚“托管资源”和“非托管资源”,只有非托管资源才需要使用 using 关键字。
关于非托管资源和托管资源可以看这篇博客【 】
还记得在 Java 中写字段的读写方法时,快捷键用的相当的 6 ,那么 C# 中没有与其类似的对象呢,快捷键当然有,不过还有更猛的,就是不用写字段了,只管写读写属性就好,编译器会自动根据读写属性去生成字段。
public class Person { public string Name { get; set; } public int Age { get; set; } public string Sex { get; set; } }编译器在编译时就会自动生成字段,下面是编译过后的 IL代码目录,可以看到最下面生成了三个字段。
一个问号见过,在三目元算符里面就是。两个问号呢?
之前见到这样的写法也是比较奇葩的。看代码吧:
public class Program { public static void Main(string[] args) { string a = null; var b = a ?? "woaini"; Console.WriteLine("b : " + b); Console.WriteLine("============="); a = "msym"; var c = a ?? "woaini"; Console.WriteLine("c: " + c); } }运行看结果:
结论就是:问号左边的是 null 得话,那么得到就是问号右边的值,反之就是问号左边的值。
这个可以看这个博客【C# 中的扩展方法】
还有这个博客,扩展方法的运用【扩展方法的运用】
其实我对扩展方法的理解,就是一个特殊的工具类,只不过和类型绑定在一起了。这只是我暂时的理解,因为还没涉及到底层。
【未完待续】
【回到主页】
标签:编译器 自动生成 string 奇葩 tle href stat 技术分享 比较
原文地址:http://www.cnblogs.com/daimajun/p/6850550.html