类的构造器[constructor]_C#
类的构造器(constructor):
1. 先看两个类定义:
class A{ }
相当于:
class A: object
{
Public A ( ) : base( )
{ }
}
2. 在类定义中定义自定义构造函数,默认构造函数会被默默地删除; 所以必须为类显式重定义默认构造函数,否则不能使用默认构造函数创建类类型的实例.
3. 看一个代码:
using System ;
class A
{
public A()
{
Console .WriteLine ("我来了");
}
}
class Test
{
static void Main()
{
A a = new A ();
}
}
输出: 我来了 .
->构造器在类实例化的过程中执行.
->构造器没有返回值.
4. 类在实例化的时候会对它的成员变量进行初始化; 但在使用局部变量之前必须要赋值.
using System ;
class A
{
public int i;
public string s;
}
class Test
{
static void Main()
{
A a = new A ();
Console .WriteLine ("i="+a.i);
Console .WriteLine ("s="+a.s);
}
}
输出: i=0
S=
5. 构造器重载:
using System ;
class A
{
public int i;
public string s;
public A()
{
}
public A(int i)
{
this.i=i;
}
public A(string s)
{
this.s=s;
}
public A(int i , string s)
{
this.i=i;
this.s=s;
}
}
class Test
{
static void Main()
{
A a = new A ();
Console.WriteLine ("第一个构造器");
Console .WriteLine (a.i);
Console .WriteLine (a.s);
A a1 = new A (1);
Console.WriteLine ("第二个构造器");
Console .WriteLine (a1.i);
Console .WriteLine (a1.s);
A a2 = new A ("我是第三个");
Console.WriteLine ("第三个构造器");
Console .WriteLine (a2.i);
Console .WriteLine (a2.s);
A a3 = new A (3,"我是第四个");
Console.WriteLine ("第四个构造器");
Console .WriteLine (a3.i);
Console .WriteLine (a3.s);
}
}
6. 成员变量初始化: C#允许在声明成员变量时对其进行初始化,但这样会产生代码冗余.
using System ;
class A
{
public int i=100;
public string s="森林";
public A()
{
}
public A(int i)
{
this.i=i;
}
public A(string s)
{
this.s=s;
}
public A(int i , string s)
{
this.i=i;
this.s=s;
}
}
可改成:
using System ;
class A
{
public int i;
public string s;
public A()
{
i=100;
s="森林";
}
public A(int i):this() //注意this的使用
{
this.i=i;
}
public A(string s):this()
{
this.s=s;
}
public A(int i , string s):this()
{
this.i=i;
this.s=s;
}
}
7. 看一段代码:
using System ;
class A
{
public A()
{
Console .WriteLine ("我是类A的无参构造器");
}
public A(int i)
{
Console .WriteLine ("我是类A的带有一个参数的构造器");
}
}
class B:A
{
public B()
{
Console .WriteLine ("我是类B的无参构造器");
}
public B(int i)
{
Console .WriteLine ("我是类B的带有一个参数的构造器");
}
}
class Test
{
static void Main()
{
B b=new B (100);
}
}
输出: 我是类A的无参构造器
我是类B的带有一个参数的构造器
è 继承类在实例化的时候会自动调用父类的无参构造器,如果找不到, 会报错. 除非继承类有另外指定.
è 在C#中,除非另外指定,基类的默认构造函数是在执行自定义的子类构造函数逻辑之前自动调用的;
è 为优化派生类的创建,应该显式调用一个合适的自定义基类构造函数而不是默认(基类)构造函数来实现子类构造函数;
.作为一般规则, 所有的子类应该显式调用一个合适的基类构造函数;
8. base和this关键字的使用:
->this关键字作用: (1) 进行自引用; (2) 转发构造函数调用 .
->this是个隐含指针, 指向类实例化后的对象本身.
->在任何子类想访问由父类定义的公共或受保护成员时,都可以使用base关键字, 并不限制在构造函数逻辑中;
using System ;
class A
{
public A()
{
Console .WriteLine ("我是类A的无参构造器");
}
public A(int i)
{
Console .WriteLine ("我是类A的带有一个参数的构造器");
}
}
class B:A
{
public B()
{
Console .WriteLine ("我是类B的无参构造器");
}
public B(int i):base(i) //注意base的使用
{
Console .WriteLine ("我是类B的带有一个参数的构造器");
}
// public B(int i ,int j)
// {
// Console.WriteLine ("我是类B的带有两个参数的构造器");
// }
}
class Test
{
static void Main()
{
B b=new B (100);
}
}
输出: 我是类A的带有一个参数的构造器
我是类B的带有一个参数的构造器
9. 静态构造器(static constructor)
->静态构造函数是实现对一个类进行初始化的方法成员. 它一般用于对静态数据的初始化. 静态构造函数不能有参数,不能有修饰符而且不能被调用,当类被加载时,类的静态构造函数自动被调用.
->在一个程序的执行过程中,静态构造器最多只执行一次.
->静态构造器在类的静态成员初始化之后执行.或者说编译器会将静态成员初始化语句转换成赋值语句放在静态构造器执行的最开始.
->静态构造器在任何类的静态成员被引用之前执行.
->静态构造器在任何类的实例变量被分配之前执行.
下面这个代码,编译器会自动创建一个静态构造器:
using System ;
class A
{
public static int i=100;
public A()
{
Console .WriteLine ("我是类A的无参构造器");
}
}
再看一段代码:
using System ;
class A
{
public static int i=100;
static A()
{
Console .WriteLine ("我是类A的静态构造器");
}
public A()
{
Console .WriteLine ("我是类A的无参构造器");
}
}
class Test
{
static void Main()
{
A a = new A ();
A a1 = new A ();
}
}
输出: 我是类A的静态构造器
我是类A的无参构造器
我是类A的无参构造器
è 静态构造器只执行一次.
类的构造器[constructor]_C#的更多相关文章
- C#.NET常见问题(FAQ)-构造器constructor有什么用
所谓的构造器constructor,就是声明类的时候定义一个public 类名的方法,这个方法不需要传递任何数据,这样的话在声明任何类的实例的时候都会无条件执行里面的方法 析构器只在程序销毁的时候 ...
- 【Java面试题】7 构造器Constructor是否可被override?
构造器Constructor不能被继承,因此不能重写Override,但可以被重载Overload. Constructor不能被继承,所以Constructor也就不能被override.每一个类必 ...
- 构造器Constructor
构造器Constructor是否可被override构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载Overloading 首先,构造器是不能被继承的,因为每个类 ...
- 构造器Constructor是否可被override?
构造器Constructor是否可被override? 构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载Overloading.
- Java8自定义函数式编程接口和便捷的引用类的构造器及方法
什么是函数编程接口? 约束:抽象方法有且只有一个,即不能有多个抽象方法,在接口中覆写Object类中的public方法(如equal),不算是函数式接口的方法. 被@FunctionalInterfa ...
- 类的构造器-init和new
提到构造器,大家都会想到 __init__,那么__new__是什么?也是构造器. init 构造器 都很熟悉了,直接上代码 class MyClass(object): def __init__(s ...
- Scala类的构造器与访问器
1.构造器 在Scala中,每个类都有一个主构造器.主构造器与类的定义交织在一起,如下: class Person ( private var _name: String, private var _ ...
- 方法引用_通过this引用本类的成员方法和方法引用_类的构造器(构造方法)引用和数组的构造器引用
package com.yang.Test.ThisMethodReference; /** * 通过this引用本类的成员方法 */ public class Husband { //定义一个买房子 ...
- jnhs-java实体类的有参构造器 无参构造器Could not instantiate bean class 实体类No default constructor found
new一个对象的时候要用到构造函数, 例如Hello hello = new Hello();这时调用的是Hello的无参数构造方法; Hello hello = new Hello("hi ...
随机推荐
- contiki Makefile.include 四个关注点<contiki学习之二>
Contiki Makefile.include 笔记 约定: makefile 包括Makefile.Makefile.xxx,并不单指Makefile 不对makefile的语法进行分析,仅仅关 ...
- DuiVision开发教程(17)-对话框
DuiVision的对话框类是CDlgBase. 代码中假设须要创建一个对话框,一般建议使用DuiSystem类中封装的若干对话框相关的函数来操作,包括创建对话框.删除对话框.依据对话框名获取对话框指 ...
- Java模拟登陆02【转载】
在使用java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆.那么,如何解决这个问题呢? 方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时 ...
- hdu 5587 Array 数学题
Array Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5587 De ...
- Codeforces Gym 100418J Lucky tickets 数位DP
Lucky ticketsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view ...
- 杭电 3177 Crixalis's Equipment
http://acm.hdu.edu.cn/showproblem.php? pid=3177 Crixalis's Equipment Time Limit: 2000/1000 MS (Java/ ...
- C++ CheckBox_Porerty
主题 1. s Caption属性 CheckBox CheckDlgButton BOOL CheckDlgButton( HWND hDlg, // handl ...
- web开发技术点解析
一.控件篇 1.radio控件 在创建单选控件时,要做到多个radio有单选功能.必须把多个radio的name属性值设置为同样的,否则,多个radio之间是没有联系的. 二.样式篇 1.获取图片中的 ...
- C 高级编程 2 内存管理
理解malloc的工作原理: malloc使用一个数据结构(链表)来维护分配的空间.链表的构成: 分配的空间.上一个空间的地址.下一个空间的地址.以及本空间的信息等. 对malloc分配的空间不要越界 ...
- 一个想法(续二):换个角度思考如何解决IT企业招聘难的问题!
前言: 上一篇文章:一个想法:成立草根技术联盟对开发人员进行技术定级解决企业员工招聘难问题! 当时写文的思维,是从一个公益组织的角度的思考. 因此,有不少关于从利出发的反方观点,的确是值的思考! 任何 ...