构造函数

Posted weihengblogs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了构造函数相关的知识,希望对你有一定的参考价值。

构造函数主要是用来创建对象时为对象赋初值来初始化对象。总与new运算符一起使用在创建对象的语句中 。A a=new A();

构造函数具有和类一样的名称;但它是一个函数具有函数的所有特性,同一个类里面可以有多个参数不同的构造函数,也就是函数的多态。

构造函数是在实例化类时最先执行的方法,通过这个特性可以给对象赋初值。

构造函数没有返回值,也不能用void修饰,只有访问修饰符。

每个类中都会一个构造函数,如果用户定义的类中没有显式的定义任何构造函数,编译器就会自动为该类型生成默认构造函数,类里面没有构造函数也可以,系统会为你自动创建无参构造函数。

 

例:class test //test类
{
   public test()
    {
     //构造函数,初始化对象
   }
}

构造函数,目的是用于初始化类。比如你定义了一个类A
class A
那么构造函数写法就是
public A()  //括号内可以有参数
{
   //用于初始化的语句(没有参数就叫做默认构造函数)
}
//注意:一个类可以有多个构造函数,可根据其参数个数的不同或参数类型的不同来区分它们 即构造函数的重载。
每次要用类A时,比如 A a = new A(); //如果前面定义的构造函数有参数,那这里必须传参
构造函数不能被直接调用,必须通过new运算符在创建对象时才会自动调用;而一般的方法是在程序执行到它的时候被调用的;每次实例化(既上面的new A())一个类时,就会调用构造函数。

虽然在一般情况下,构造函数不被显式调用,而是在创建对象时自动被调用。但是并不是不能被显示调用。有些时候是一定要显示调用的,只要是父类有带参的构造函数,在子类中就必须显示的调用父类的构造函数,因为子类的构造器在实例化时无法找到父类的构造函数(当父类有自己写的无参构造函数时,子类也不用显示调用)。

构造函数的重载:所谓重载,就是参数列表不同的几个同名方法,构造函数的重载其实和方法的重载没什么太大的区别,无非访问修饰符为public ,没用返回值类型。下面写一个小例子:

技术分享图片
 1 class Animal
 2     {
 3         static void Main(string[] args)
 4         {
 5             //方法一
 6             Animal animal1 = new Animal();
 7             animal1.Name = "兔子";
 8             animal1.Color = "白色";
 9             animal1.Speed = 20;
10             animal1.Run();
11             //方法二
12             Animal animal2 = new Animal("兔子", "黑色");
13             animal2.Run(30);
14             //方法三
15             Animal animal3 = new Animal("狗", "棕色", 50);
16             animal3.Run();
17             Console.WriteLine();
18         }
19         //构造函数重载
20         public Animal()
21         {
22         }
23         public Animal(string name, string color)
24         {
25             this.name = name;
26             this.color = color;
27         }
28         public Animal(string name, string color, int speed)
29         {
30 
31             this.name = name;
32 
33             this.color = color;
34 
35             this.speed = speed;
36         }
37 //名称 38 private string name; 39 public string Name 40 { 41 get { return name; } 42 set { name = value; } 43 } 44 //颜色 45 private string color; 46 public string Color 47 { 48 get { return color; } 49 set { color = value; } 50 } 51 //速度 52 private int speed; 53 public int Speed 54 { 55 get { return speed; } 56 set { speed = value; } 57 } 58 //方法的重载Run方法的不同实现 59 public void Run() 60 { 61 Console.WriteLine("一只" + this.color + "的" + this.name + "正在以" + this.speed + "Km/h的速度在奔跑 "); 62 63 } 64 public void Run(int speed) 65 { 66 67 Console.WriteLine("一只" + this.color + "的" + this.name + "正在以" + speed + "km/h的速度在奔跑 "); 68 69 } 70
71 }


技术分享图片

 

结果如下图所示:Run方法的两种重载实现是一样的。

技术分享图片

以上是关于构造函数的主要内容,如果未能解决你的问题,请参考以下文章

Android 逆向ART 脱壳 ( DexClassLoader 脱壳 | DexClassLoader 构造函数 | 参考 Dalvik 的 DexClassLoader 类加载流程 )(代码片段

防止 Proguard 删除片段的空构造函数

无法解析片段中的 ViewModelProvider 构造?

为啥要避免片段中的非默认构造函数?

片段真的需要一个空的构造函数吗?

这个嵌套类构造函数片段可以应用于泛型类吗?