zoukankan      html  css  js  c++  java
  • c# base 和this 继承

    父类的构造函数总是在子类之前执行的。既先初始化静态构造函数,后初始化子类构造函数。

    复制代码
    复制代码
    public class BaseCircle {
            public BaseCircle()
            {
                Console.WriteLine(" no arguments base constructor!!!");
            }
            public BaseCircle(double arg)
            {
                Console.WriteLine("double arg base constructor!!!");
            }
        }
     
        public class SubCircle : BaseCircle {
            public SubCircle():base()
            {
                Console.WriteLine("sub class no argument constructor,actually call base constructor !!!");
            }
     
            public SubCircle(double a):base(a)
            {
                Console.WriteLine("sub class with argument, actually call base double constructor!!!");
            }
     
            public SubCircle(int k):this(1,2)
            {
                Console.WriteLine("sub class with argument int k, actually call sub class constructor int i & j !!!");
            }
     
            public SubCircle(int i,int j)
            {
                Console.WriteLine("sub class with int i&j argument!!!!");
            }
        }
     
    static void Main(string[] args)
            {
                SubCircle s1 = new SubCircle();
                SubCircle s2 = new SubCircle(1.1);
                SubCircle s3 = new SubCircle(1);
    }
    复制代码
    复制代码
    复制代码
    复制代码
    输出结果:
    no arguments base constructor!!!
    sub class no argument constructor,actually call base constructor !!!
     
    double arg base constructor!!!
    sub class with argument, actually call base double constructor!!!
     
     no arguments base constructor!!!
    sub class with int i&j argument!!!!
    sub class with argument int k, actually call sub class constructor int i & j !!!
    复制代码
    复制代码

    用法二:                                                                                                                                                                                                                        

    是不是很模糊这两个关键字那?


    哈,现在我来写份代码,代码可是最有说服力的啦!

    复制代码
    复制代码
     class BaseClass
        {
            private int numA;
            public BaseClass()
            {
                Console.WriteLine("基类的无参数构造函数. value:{0}", numA);
            }
            public BaseClass(int i)
            {
                this.numA = i;
                Console.WriteLine("基类带一个参数的构造函数. value:{0}", numA);
            }
        }
        class ChildClassA : BaseClass
        {
            private int numB;
            public ChildClassA()
            {
                Console.WriteLine("子类无参数构造函数. value:{0}", numB);
            }
            public ChildClassA(int i)
            {
                this.numB = i;
                Console.WriteLine("子类带有一个参数的构造函数. value:{0}", numB);
            }
            public ChildClassA(int i, int j)
                : base(i)
            {
                this.numB = j;
                Console.WriteLine("子类带有两个参数的构造函数. value:{0}", numB);
            }
        }
        class ChildClassB : BaseClass
        {
            private int numB;
            public ChildClassB()
            {
                Console.WriteLine("子类无参数构造函数. value:{0}", numB);
            }
            public ChildClassB(int i)
            {
                this.numB = i;
                Console.WriteLine("子类带有一个参数的构造函数. value:{0}", numB);
            }
            public ChildClassB(int i, int j)
                : this(i)
            {
                this.numB = j;
                Console.WriteLine("子类带有两个参数的构造函数. value:{0}", numB);
            }
        }
        class Demo
        {
            static void Main(string[] args)
            {
                Console.WriteLine("使用base
    ");
                ChildClassA a = new ChildClassA(2, 4);
                Console.WriteLine();
                Console.WriteLine("----------------------------------------
    ");
                Console.WriteLine("使用this
    ");
                ChildClassB b = new ChildClassB(2, 4);
                Console.ReadKey();
            }
        }
    复制代码
    复制代码

    执行的结果如下:

    复制代码
    复制代码
    --------------------------------结果----------------------------------
     
    使用base
     
    基类带一个参数的构造函数. value:2
    子类带有两个参数的构造函数. value:4
     
    ----------------------------------------
     
    使用this
     
    基类的无参数构造函数. value:0
    子类带有一个参数的构造函数. value:2
    子类带有两个参数的构造函数. value:4
     
    --------------------------------结果--------------------------------
    复制代码
    复制代码

    this只是调用本身,但是这样是需要调用一次基类没有参的构造函数,所以会多显示一条“基类的无参数构造函数. value:0”。

    base是调用基类的有参数构造函数。

  • 相关阅读:
    动态规划2.1 矩阵中的最短路径
    动态规划3.3 最长递增子序列
    动态规划3.2 最长公共子串
    动态规划3.1 求两个字符串的莱文斯坦编辑距离
    大数相乘
    科大讯飞C++面试经验
    存储世界的两个祖师爷和他们的后代们!!!
    读写(I/O)辩论
    集线器(HUB)、交换机、路由器的区别和联系 及OSI七层模型 及TCP/IP通信协议
    HTTP协议
  • 原文地址:https://www.cnblogs.com/HKKD/p/7015862.html
Copyright © 2011-2022 走看看