Chinaunix首页 | 论坛 | 博客
  • 博客访问: 581812
  • 博文数量: 208
  • 博客积分: 3286
  • 博客等级: 中校
  • 技术积分: 1780
  • 用 户 组: 普通用户
  • 注册时间: 2007-09-24 20:38
文章分类

全部博文(208)

文章存档

2012年(7)

2011年(28)

2010年(21)

2009年(76)

2008年(65)

2007年(11)

我的朋友

分类:

2009-09-04 11:27:38

浅谈C#中构造函数与析构函数
2008-12-11 21:46

构造函数和析构函数

本节说明对象的创建、初始化和销毁过程。本节介绍下列主题:

l         类构造函数

l         结构构造函数

l         析构函数

类构造函数

本节将讨论三种类构造函数:

类构造函数的类型

注释

实例

用于创建并初始化类的实例。

私有

在类之外不可访问的特殊类型实例构造函数。无法用私有构造函数来实例化类。

静态

在创建第一个实例或引用任何静态成员之前,将自动调用这种构造函数来初始化类。无法直接调用这种构造函数。

备注

       (1) 实例构造函数

       创建新对象时将调用类构造函数,例如:

       Point myPoint = new Point();

       一个类可以有多个构造函数。例如,可以声明一个不带参数的构造函数(如 Point())和一个带参数的构造函数(如 Point(int x, int y))。

       如果类没有构造函数,将自动生成一个默认的无参数构造函数,并使用默认值初始化对象字段(例如,int 将初始化为 0)。

       类构造函数可通过base关键字来调用基类的构造函数,例如:

       public Cylinder(double radius, double height): base(radius, height)

       {

       }

       类构造函数也可通过关键字 this 调用同一个类的另一个构造函数,例如:

       public Point(): this(0,20)

       {

       }

       在前面的示例中,无参数构造函数 Point() 调用了另一个带有两个参数的构造函数,将默认位置初始化为 (0, 20)。

       (2)私有构造函数

       私有构造函数是一种特殊的实例构造函数。它通常用在只包含静态成员的类中。如果类具有一个或多个私有构造函数而没有公共构造函数,则不允许其他类(除了嵌套类)创建该类的实例。例如:

       class NLog

       {

            // Private Constructor:

            private NLog() {}

            public static double e = 2.71828;

       }

       声明空构造函数可阻止自动生成默认构造函数。注意,如果您不对构造函数使用访问修饰符,则在默认情况下它仍为私有构造函数。但是,通常显式地使用 private(私有)修饰符来清楚地表明该类不能被实例化。

       (3)静态构造函数

       静态构造函数用于初始化类。在创建第一个实例或引用任何静态成员之前,将自动调用静态构造函数来初始化类。

       静态构造函数既没有访问修饰符,也没有参数。

       在创建第一个实例或引用任何静态成员之前(方法或字段),将自动调用静态构造函数来初始化类。

       无法直接调用静态构造函数。静态构造函数也不能访问非静态成员,它只被调用一次

       在程序中,用户无法控制何时执行静态构造函数。

       静态构造函数的典型用途是:当类使用日志文件时,将使用这种构造函数向日志文件中写入项。

结构构造函数

       结构构造函数类似于类构造函数,只是存在以下差异:

n         结构不能包含显式的无参数构造函数。结构成员将自动初始化为它们的默认值。

n         结构不能有以下形式的初始值设定项:base (argument-list)。

       结构可以声明构造函数,但它们必须带参数。声明结构的默认(无参数)构造函数是错误的。结构成员不能有初始值设定项。总是提供默认构造函数以将结构成员初始化为它们的默认值。

       对于结构,不像类那样存在继承。一个结构不能从另一个结构或类继承。结构不能有以下形式的初始值设定项:base (argument-list)。

析构函数

       析构函数用于销毁类的实例。

       备注

              不能对结构使用析构函数。只能对类使用析构函数。

              一个类只能有一个析构函数。

              无法继承或重载析构函数。

              无法调用析构函数。它们是被自动调用的。

              析构函数既没有修饰符,也没有参数。例如,下面是类 MyClass 的析构函数的声明:

                     ~ MyClass()

                     {

                          // Cleanup statements.

                     }

       该析构函数隐式地对对象的基类调用 Object.Finalize 方法。这样,前面的析构函数代码被隐式地转换为:

              protected override void Finalize()

              {

                   try

                    {

                        // Cleanup statements.

                }

                   finally

                   {

                        base.Finalize();

                   }

              }

       这意味着对继承链中的所有实例递归地(从派生相近程度最大的到派生相近程度最小的)调用 Finalize 方法。

       程序员无法控制何时调用析构函数,因为这由垃圾回收器决定的。垃圾回收器检查是否存在应用程序不再使用的对象。它认为这些对象符合销毁条件并回收这些对象占用的内存。程序退出时也会调用析构函数。

base关键字

       base 关键字用于从派生类中访问基类的成员:

       调用基类上已被其他方法重写或隐藏的方法。

       指定创建派生类实例时应调用的基类构造函数。

       基类访问只能在构造函数、实例方法或实例属性访问器中进行。

       静态方法中使用 base 关键字是错误的。

This 关键字

       this 关键字表示类的当前实例。

       静态成员没有 this 指针。

       访问被相同的名称隐藏的成员。

       如:

              public Employee(string name, string alias)

              {

                   this.name = name;

                   this.alias = alias;

              }

       将this作为参数传递到其他方法。

       如:

       CalcTax(this);

       声明索引器,例如:

       public int this [int param]

       {

      get

      {

         return array[param];

      }

      set

      {

         array[param] = value;

      }

   }

       调用同类中其它的构造函数

       静态方法、静态属性访问器引用 this 是错误的。

[转]http://www.cnblogs.com/liyingyi/archive/2006/01/07/312897.html

看了上面的文章,让我想起了嵌套类,嗯,我从没用过这样的类,查了下它的用法,总结如下“

看下面这个链接,这个很好懂。

http://hi.baidu.com/rafale88/blog/item/14628b305082e1ae5fdf0e55.html

深入的,看这里:

http://blog.csdn.net/mydriverc/archive/2008/03/01/2137884.aspx

关于枚举的:
http://www.cnblogs.com/liyingyi/archive/2005/12/28/306772.aspx

阅读(745) | 评论(0) | 转发(0) |
0

上一篇:.NET 接口和抽象类

下一篇:C#中类的继承

给主人留下些什么吧!~~