C# 我是个传奇的 using

   呵呵呵: 

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

   丶丶丶丶丶丶释放对象所占用的非托管资源,要保证Dispose方法能在使用完对象后被调用,.Net提供了using程序块和try-finally程序块两个方法,两者没有太大的区别,可能使用using能使程序看得比较简明,但是为了防止异常,需要在using中加入try-catch  丶丶丶丶丶丶丶丶丶

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

关于  ‘新老朋友’ 《using》

  第一种:

  命名空间:

using namespace std;说明using的使用,必须先了解命名空间的概念和使用。

在一个给定作用域中定义的每个名字在该作用域中必须是唯一的,对庞大、复杂的应用程序而言,这个要求可能难以满足。这样的应用程序的全局作用域中一般有许多名字定义。由独立开发的库构成的复杂程序列更有可能遇到名字冲突,同样的名字既可能在我们自己的代码中使用,也可能(更常见地)在独立供应商提供的代码中使用。库倾向于定义许多全局名字——主要是模板名、类型名或名。在使用来自多个供应商的库编写应用程序时,名字冲突的问题尤为突出。这个问题叫命名空间污染。

命名空间为了解这个问题而应运而生。每个命名空间是一个作用域,命名空间中的每个名字必须引用该命名空间中的唯一实体。命名空间可以是不连续的,还可以嵌套。前面所述的std就是C++的标准命名空间,C++标准内容的名字都放在它里面。

  第二种

  释放资源:

使用非托管资源的类型必须实现IDisposable接口的Dispose()方法来精确的释放系统资源。.Net环境的这一规则使得释放资源代码的职责是类型的使用者,而不是类型或系统。因此,任何时候你在使用一个有Dispose()方法的类型时,你就有责任来调用Dispose()方法来释放资源。最好的方法来保证Dispose()被调用的结构是使用using语句或者try/finally块。 所有包含非托管资源的类型应该实现IDisposable接口,另外,当你忘记恰当的处理这些类型时,它们会被动的创建析构函数。如果你忘记处理这些对象,那些非内存资源会在晚些时候,析构函数被确切调用时得到释放。这就使得这些对象在内存时待的时间更长,从而会使你的应用程序会因系统资源占用太多而速度下降。 
幸运的是,C#语言的设计者精确的释放资源是一个常见的任务。他们添加了一个关键字来使这变得简单了。

 
posted @ 2016-05-09 16:20  零星一点  阅读(506)  评论(1编辑  收藏  举报