zoukankan      html  css  js  c++  java
  • 关于类、继承、抽象方法、构造函数等求输出结果的一些面试题

    有好多面试的时候写几个类互相继承,里面有抽象方法,然后各种实例化,搞的晕头转向的,在这里稍微总结下,以后慢慢地补充:

    1:

     1 class A
     2     {
     3         public A()
     4         {
     5 
     6             PrintFields();
     7         }
     8         public virtual void PrintFields() { }
     9     }
    10     class B : A
    11     {
    12         int x = 1;
    13         int y;
    14         public B()
    15         {
    16             y = -1;
    17         }
    18         public override void PrintFields()
    19         {
    20             Console.WriteLine("x={0},y={1}", x, y);
    21         }
    22     }
    View Code

    当使用new B()创建B的实例时,产生什么输出?

    这个应该算是简单的,但是也有很多对于继承构造函数的执行顺序不清的弄得苦不堪言。

    分析:

      当new B()输出的为X= 1 ,Y = 0;
       1、在new B()是会先调父类即A的构造函数,这时会执行PrintFields();方法,因为PrintFields方法为虚拟方法,在子类中重写的该方法,所在实际执行的为B中的PrintFields方法。
       2、为什么Y=0?这是因在调用的是父类方法,子类的中的Y还没初始会,系统自己赋值为0。

    2:

    下面这一个问题是在第一个的基础上进行扩展下

     1  class A
     2     {
     3         public A()
     4         {
     5 
     6             PrintFields();
     7         }
     8         public virtual void PrintFields() { }
     9     }
    10     class B : A
    11     {
    12         int x = 1;
    13         public int y;
    14         public B()
    15         {
    16             y = -1;
    17         }
    18         public override void PrintFields()
    19         {
    20             Console.WriteLine("x={0},y={1}", x, y);
    21         }
    22     }
    23     public class C
    24     {
    25 
    26         public static void Main()
    27         {
    28             B b = new B();
    29             Console.WriteLine("Y={0}", b.y);
    30             Console.Read();
    31 
    32         }
    33     }
    View Code

    分析:

      答案为:X=1,Y = 0
                  Y = -1

    至于为啥,各位打个断电调试下就知道了

    3:

    下面这个题各位不知道有没有犯迷糊的

     1 static Person GetPerson()
     2         {
     3             Person p = new Person();
     4             p.Age = 8;
     5             try
     6             {
     7                 p.Age++;
     8                 return p;
     9             }
    10             finally
    11             {
    12                 p.Age++;
    13             }
    14          }
    15 static int stac()
    16         {
    17             int i = 8;
    18             try
    19             {
    20                 i++;
    21                 return i;
    22 
    23             }
    24             finally
    25             {
    26                 i++;
    27             }
    28         }
    29 
    30 public static void Main()
    31         {
    32             Console.WriteLine(GetPerson().Age);
    33             Console.WriteLine(stac());
    34         }    
    View Code

    这个破题,真不知道该说啥了,直接公布结果:第一个为10,第二个为9

    4:

    上面的懂了,请看下一题

     1     class A
     2     {
     3         public static int X;
     4         static A()
     5         {
     6             X = B.Y + 1;
     7         }
     8     }
     9     class B
    10     {
    11         public static int Y = A.X + 1;
    12         static B() { }
    13         static void Main()
    14         {
    15             Console.WriteLine("X={0},Y={1}", A.X, B.Y);
    16             Console.ReadKey();
    17         }
    18     }
    View Code

    答案是 1,2

    看一下别人写的结论吧,我觉得说的听明白了,自己就不再多说了:

    因为执行的时候,首先从程序的入口点(就是Main())找起,因为Main在类B中,所以从B类开始加载。执行顺序大致是这样的:
    (用到一个类的时候是先对其静态变量初始化,然后调用他的静态构造函数)
    (类的静态构造函数只在加载类的时候由系统调用一次且只此一次)
    1.初始化B类的静态变量 Y,系统先给他一个默认值(此处是0),然后再执行他的初始化赋值语句public static int Y = A.X + 1;
    2.执行这条语句的时候因为用到了A.X,所以遇到A的时候去加载类A,顺序一样,先是执行A的静态变量X的初始化工作public static int X;因为没有对其赋值的操作,所以X就是系统给他的默认值0;然后调用A的静态构造函数(B那里也是先初始化静态变量,然后才调用静态构造函数,因为B初始化静态变量的时候用到了A所以才会跳到A来,不然的话B那边也是初始化静态变量之后系统紧接着就会调用B的静态构造函数);
    3,A的静态构造函数中执行X = B.Y + 1;可以知道,此时B.Y已经有了一个系统给他的默认值0,所以此处就是X=0+1;现在X就是1了
    4,X那边都完工了,回到刚才跳转X的地方继续执行,就是继续执行Y = A.X + 1;毫无疑问此时是Y=1+1;至此,B的静态变量初始化完成了。
    5,B的静态变量初始化完成了那紧接着就是系统调用B的静态构造函数,此处什么也不执行。
    6.输出结果1,2
     
  • 相关阅读:
    Jmeter测试接口详细步骤(三)跨线程组传值-BeanShell 后置处理程序
    Jmeter测试接口详细步骤(二)HTTP Cookie管理器
    Jmeter测试接口详细步骤(一)基础操作
    最优化学习3
    最优化学习2
    最优化学习---从解方程到最优化1
    最优化学习---从解方程到最优化
    博客园 文章和随笔区别 (转
    refinedet tensorRT实现
    crnn pytorch 训练、测试
  • 原文地址:https://www.cnblogs.com/jiaxa/p/3594039.html
Copyright © 2011-2022 走看看