用法一:

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

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\n");
ChildClassA a = new ChildClassA(2, 4);
Console.WriteLine();
Console.WriteLine("----------------------------------------\n");
Console.WriteLine("使用this\n");
ChildClassB b = new ChildClassB(2, 4);
Console.ReadKey();
}
} 执行的结果如下: --------------------------------结果---------------------------------- 使用base 基类带一个参数的构造函数. value:2
子类带有两个参数的构造函数. value:4 ---------------------------------------- 使用this 基类的无参数构造函数. value:0
子类带有一个参数的构造函数. value:2
子类带有两个参数的构造函数. value:4 --------------------------------结果---------------------------------- this只是调用本身,但是这样是需要调用一次基类没有参的构造函数,所以会多显示一条“基类的无参数构造函数. value:0”。 base是调用基类的有参数构造函数。 够简洁明了吧,看了就懂,希望能给网友一些帮助。

  

C#构造函数里的base和this的区别的更多相关文章

  1. 构造函数this和base的区别

    构造函数this和base的区别: this:调用的是本身,不能调用父类和子类的 base:调用父类的,不能调用本身的,但别人继承,可以调用 从中也可以得出另外个结果构造函数的运行过程 先从基类开始构 ...

  2. 构造函数后面的base()

    先执行父类的对应的构造函数,再执行当前的构造函数. 关于子类对象的构造函数和父类构造函数的执行顺序 以下内容转自:http://blog.csdn.net/todototry/article/deta ...

  3. SAP MM 预留单据里的Base date和Requirement date

    SAP MM 预留单据里的Base date和Requirement date Base date可以在预留创建的初始界面指定, 这个日期可以作为预留各个行项目默认的requirement date. ...

  4. C++ 里大写TRUE和小写true区别

    1.C++里大写TRUE和小写true区别 true是bool型的: TRUE是int型的,VC里这个是ms自己定义的: C++规定不允许只通过返回类型不同区别两个函数 2.MFC中的”false“和 ...

  5. 《more effective C++》条款10 防止构造函数里的资源泄露

    构造函数也可能发生内存泄露,考虑如下程序: class A { public: A(int *p) { if(p!=NULL) num=p; ); //do something } private: ...

  6. 构造函数中base与this的区别

    base是对父类的引用,而this是对类本身的引用. namespace ConsoleApplication1 { public class BaseClass { private string n ...

  7. 在全局对象(不是指针)的构造函数里不要对std集合做太多操作

    写MaxvisionOnvif的时候,我用个宏把每个Command类注册到了CommandBuilder里面,通过全局对象初始化实现的,如下: void CommandBuilder::Registe ...

  8. Qt设置窗口的初始大小(使用sizeHint这个虚函数,或者在构造函数里使用resize函数)

    我们用qt创建一个窗口,先后显示它,代码如下: class Mywindow : public QMainWindow{ ..... } int main( int argc, char** argv ...

  9. Autowired注解的妙用---在Controller里的构造函数里获取需要注入的对象

    /*@Resource private Observer<TaxiObserverVo> taxiPushObserver; @Resource private Observer<T ...

随机推荐

  1. 【POJ2985】【Treap + 并查集】The k-th Largest Group

    Description Newman likes playing with cats. He possesses lots of cats in his home. Because the numbe ...

  2. PHPCMS V9调用时间标签 |日期时间格式化

    PHPCMS V9 如何调用时间标签,下面分享常见的调用时间标签 |日期时间格式化  1.日期时间格式化显示: a标准型:{date('Y-m-d H:i:s', $rs['inputtime'])} ...

  3. psql rank row

    rank() OVER (PARTITION BY f1 ORDER BY f2 DESC) ROW_NUMBER() () OVER (PARTITION BY f1 ORDER BY f2 DES ...

  4. 错误: 找不到或无法加载主类 scala.tools.nsc.MainGenericRunner

    错误: 找不到或无法加载主类 scala.tools.nsc.MainGenericRunner 原因: Sacala安装路径中包含空格.

  5. Labeling Balls

    poj3687:http://poj.org/problem?id=3687 题意:有N个重量1到N的点,把这N个点涂色,要求在一定的约束下颜色a必须比颜色b要轻,如果有多种选择则让重量最小的对应编号 ...

  6. hdu 5063 Operation the Sequence

    http://acm.hdu.edu.cn/showproblem.php?pid=5063 思路:因为3查询最多50,所以可以在查询的时候逆操作找到原来的位置,然后再求查询的值. #include ...

  7. java 和javaw 的区别——<转>

    java 和javaw 的区别 javaw.exe用法和java.exe 相同 javaw的程序不在java console 上面显示任何东西,如果在开发程序,就用java,这样可以看到错误提示, 如 ...

  8. 关于form.item不兼容的问题

    form.item()能在IE下运行,在firefox中会报脚本错误,没有这个函数. 可以使用 Form.elements 方法得到 HTMLCollection 后再使用 item 方法获取表单内元 ...

  9. 微控制器(MCU)架构介绍

    微控制器(MicroController)又可简称MCU或μC,也有人称为单芯片微控制器(Single Chip Microcontroller),将ROM.RAM.CPU.I/O集合在同一个芯片中, ...

  10. 想做Android Wear开发?你得先搞明白这四件事

    手环和手表的腕上穿戴之争,随着Apple Watch发布和Android Wear不断完善而告一段落.尽管续航上略有缺陷,但手表以其类似手机可扩展的生态环境赢得了众多巨头的支持. Google曾透露, ...