最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Java中类的构造器讲解
时间:2015-07-27 编辑:简简单单 来源:一聚教程网
Java在使用new创建对象时,会调用其构造器,构造器与方法不同,其没有返回值,且其名字与类名一致,在构造器中,我们可以初始化类的一些fields,这样,当我们创建好对象后,这些对象都有了默认的初始值 。
当我们的类在继承父类的时候,在创建子类对象的时候,首先会调用父类的构造器,实际上,父类的构造器在调用之前,会继续调用Object类的构造器,当Object类的构造器调用完成之后,才调用父类的构造器,依次在调用子类的构造器。这样做的原因是,我们的子类对象的fields的值可能会依赖于父类,因此父类必须将其fields初始化好,一般来说,我们在写子类构造器的时候,无需写
super()
JVM自动帮我们调用父类的默认构造器,但是,当我们不想调用父类的默认构造器的时候,而是想调用其父类带有参数的构造器时,此时,我们需要显示地调用super(arg1,arg2,...),需要注意的是,其调用必须在构造器中首行,其原因也很简单,就是防止我们先调用了子类的构造器。
我们也可以在子类构造器中调用子类的另一个重载的构造器方法,只要使用
this(arg1,arg2,...);
即可,注意,这里的this和在方法中的this不同,方法中的this指的是当前对象,而这里的this指的是指向同一个类中,不同参数列表的另外一个构造器。
当我们重载自己的构造器的时候,JVM不会像之前那样帮我们自动创建一个默认的无参构造器。此时,我们应该自己添加上。
当我们编写下列代码时,
Dog d=new Dog();
实际上,我们在构造器的执行体之前,系统会先为该对象分配内存空间,并为这个对象执行默认初始化,此时对象已经产生了,只是这个对象还不能被外部程序访问,只能在该构造器中通过this来引用它。当构造器的执行体结束后,这个对象作为构造器的返回值被返回,通常还会赋给另一个引用类型的变量,从而让外部程序可以访问该对象。
下面我就来说说java里类的构造器概念。大家知道java作为一门OO语言,和C++,Smalltalk等一样有3个最要害:1。ADT,2。继续,3。多态
当然对于java,类的概念是重中之重,对于类的构造和对象的实现就需要用到构造器。
例如:
class PRofesser(){ private string name; private int number; public Professer(string n,int no){ name=n; number=no; } public teach(){} }
下面我们要对这个类的对象实例化:Professer p =new Professer()
以上就是构造器的语法了,这里用到了要害字
new
讲到这里还没有什么可以困扰我们的地方,那么下面我们将借助有关继续的一些例子来继续阐述构造器问题:
假设:
class OldProfesser(){ private string name; private int number ; private int age; public do(){} }
有人也许会问为什么这个OldProfesser类里面为什么没有定义构造器?其实,java已经我们定义了一个无参数的默认构造器,即OldProfesser(){}
Ok, 到这里为止,没有任何问题,然而,一旦让OldProfesser继续Professer并实例化,编译器就会报错,LOOK:
class OldProfesser extends Professer(){ private string name; private int number ; private int age; public do(){} public static void mian(string[] args){ OldProfesser o=new OldProfesser(); }
很抱歉你得到的是一条出错的信息,有人问了,你说OldProfesser的构造器是默认的我才这样写,没错,OldProfesser确实存在这样一个无参的构造器,这样写法换做OldProfesser不做Professer的子类的情况下一定是正确的。
你所需要知道的是下面一个规则:
1。假如一个类没有设置字定义构造器,那么编译器会默认一个无参构造器。
2。在子类调用构造器时,总是先调用基类的构造器。
3。假如自定义了构造器,那么默认构造器将不存在。
在上例中,OldProfesser调用默认构造器前,编译器自动调用基类Professer的默认构造器,然而,Professer有了自定义构造器,所以默认构造器不存在了,编译器报错…………
那么我们该怎么做呢?像下面这样就OK了。
class OldProfesser extends Professer(){ private string name; private int number; private int age; Oldprofesser(string n,int no,int age){ super(n,no); this.age=age; } public do(){} }
这就是在子类中显式的调用基类构造器,注重,super必须是{}中的第一个执行语句。其实我们还有另外一种方法,在Professer类里面补充一个消失掉的默认构造器,如下:
class Professer(){ private string name; private int number; public Professer(string n,int no){ name=n; number=no; } Professe(){} public teach(){} }
值得一提的是构造器方法中,构造器的名称要与类的名称完全相同,包括大小写。
相关文章
- 看看String类的构造方法 01-12
- SpringBoot测试配置属性与web启动环境解析 10-24
- vue中将el-switch值true、false改为number类型的1和0解析 10-24
- Vue中的路由配置项meta使用解读 10-24
- SpringBoot自定义bean绑定解析 10-24
- SpringBoot常用计量与bean属性校验和进制数据转换规则解析 10-24