虚拟方法的重写和静态方法的调用

来源:互联网 发布:淘宝村小二 编辑:程序博客网 时间:2024/06/06 19:17

虚拟方法的重写和静态方法的调用
1、     using System;
     class A
     {
          public A(){
                PrintFields();
           }
          public virtual void PrintFields(){}
      }
    class B : A
    {
        int x = 1;
        int y;
        public B()
        {
            y = -1;
        }
        public override void PrintFields()
        {
            Console.WriteLine("x={0},y={1}", x, y);
            Console.ReadLine();
        }

        static void Main(string[] args)
        {
            B b = new B();  // x=1  y=0
            b.PrintFields();  //x=1  y=-1
        }
当使用new B()创建B的实例时,产生什么输出?
答:X=1,Y=0
当使用new B()创建b的实例时,b.PrintFields()产生什么输出?
x=1,y=-1
2.下面的例子中
     using System;
     class A
     {
          public static int X;
          static A(){
               X=B.Y+1;
          }
      }
      class B
      {
           public static int Y=A.X+1;
           static B(){}
           static void Main(){
                Console.WriteLine("X={0},Y={1}",A.X,B.Y);
           }
       }
产生的输出结果是什么?
答:x=1,y=2

1.运行子类的构造函数时会先实行父类的构造函数,父类构造函数调用被子类覆盖的虚函数

2.而实际上,第二题是首先加载B类的代码到内存中,因为Main在B类里面。依照顺序执行的时候,发现了A.X,这时候A尚未出现,于是去找A。A加载到内存。此时X为0.B已存在,Y未赋值,自然为0.A静态部分构造完成后,X为1.回到B,此时Y = 1 + 1,也就是2.于是得到输出,X = 1,Y = 2。

如果需要证明,可以执行本人修改的代码如下:
 
 
class A
    {
        public static int X;
        static A()
        {
            Console.WriteLine("in A static,X is " + X.ToString());  //x=0
            X = B.Y + 1;
            Console.WriteLine("in A static again,X is " + X.ToString());//x=1
        }
    }
    class B
    {
        public static int Y = A.X + 1;
        static B()
        {
            Console.WriteLine("in B static,Y is " + Y.ToString());//x=2
        }
        static void Main()
        {
            Console.WriteLine("X={0},Y={1}", A.X, B.Y);
            Console.ReadLine();
        }
    }
 

原创粉丝点击