赞
踩
构造方法和实例方法的区别
一、主要的区别在于三个方面:修饰符、返回值、命名
1、和实例方法一样,构造器可以有任何访问的修饰符,public、private、protected或者没有修饰符 ,都可以对构造方法进行修饰。
不同于实例方法的是构造方法不能有任何非访问性质的修饰符修饰,例如static、final、synchronized、abstract等都不能修饰构造方法。
解释:构造方法用于初始化一个实例对象,所以static修饰是没有任何意义的;多个线程不会同时创建内存地址相同的同一个对象,所以synchronized修饰没有意义;
构造方法不能被子类继承,所以final和abstract修饰没有意义。
2、返回类型是非常重要的,实例方法可以返回任何类型的值或者是无返回值(void),而构造方法是没有返回类型的,void也不行。
3、至于命名就是构造方法与类名相同,当然了实例方法也可以与类名相同,但是习惯上我们为实例方法命名的时候通常是小写的,另一方面也是与构造方法区分开。
而构造方法与类名相同,所以首字母一般大写。
下面看几个例子熟悉一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
publicclasssample{
privateintx;
publicsample(){//不带参数的构造方法
this(1);
}
publicsample(intx){//带参数的构造方法
this.x=x;
}
publicintsample(intx){//不是构造方法
returnx++;
}
}
上面的例子即使不通过注释我们也很容易能区分开的,再看下面一个例子
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
publicclassmystery{
privatestrings;
publicvoidmystery(){//不是构造方法
s="constructor";
}
voidgo(){
system.out.println(s);
}
publicstaticvoidmain(string[]args){
mysterym=newmystery();
m.go();
}
}
程序执行的结果为null,虽然说mystery m = new mystery();调用了mystery 类的构造方法,但是public void mystery()并不是构造方法,他只是一个普通的实例方法而已,那该类的构造方法哪去了呢?
二、说到这就得说一下java的默认构造方法
我们知道,java语言中规定每个类至少要有一个构造方法,为了保证这一点,当用户没有给java类定义明确的构造方法的时候,java为我们提供了一个默认的构造方法,这个构造方法没有参数,修饰符是public并且方法体为空。
如果用户有定义构造方法,就不会有默认构造方法!!!
其实默认的构造方法还分为两种,一种就是刚刚说过的隐藏的构造方法,另一种就是显示定义的默认构造方法.
如果一个类中定义了一个或者多个构造方法,并且每一个构造方法都是带有参数形式的,那么这个类就没有默认的构造方法,看下面的例子。
1
2
3
4
5
6
7
8
9
publicclasssample1{}
publicclasssample2{
publicsample2(inta){system.out.println("myconstructor");}
}
publicclasssample3{
publicsample3(){system.out.println("mydefaultconstructor");}
}
上面的三个类中sample1有一个隐式的默认构造方法,下列语句sample1 s1=new sample()合法;
sample2没有默认的构造方法,下列语句sample2 s2=new sample2()不合法,执行会编译错误
sample3有一个显示的默认构造方法,所以以下语句sample3 s3=new sample3();合法。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。