Java中的constructorWord文件下载.docx
- 文档编号:17621858
- 上传时间:2022-12-07
- 格式:DOCX
- 页数:11
- 大小:17.21KB
Java中的constructorWord文件下载.docx
《Java中的constructorWord文件下载.docx》由会员分享,可在线阅读,更多相关《Java中的constructorWord文件下载.docx(11页珍藏版)》请在冰豆网上搜索。
this
(1);
}
publicSample(intx){//带参数的构造方法
this.x=x;
publicintSample(intx){//不是构造方法
returnx++;
上面的例子即使不通过注释我们也很容易能区分开的,再看下面一个例子
publicclassMystery{
privateStrings;
publicvoidMystery(){//不是构造方法
s="
constructor"
;
voidgo(){
System.out.println(s);
publicstaticvoidmain(String[]args){
Mysterym=newMystery();
m.go();
程序执行的结果为null,虽然说Mysterym=newMystery();
调用了Mystery类的构造方法,但是publicvoidMystery()并不是构造方法,他只是一个普通的实例方法而已,那该类的构造方法哪去了呢?
二、说到这就得说一下java的默认构造方法
我们知道,java语言中规定每个类至少要有一个构造方法,为了保证这一点,当用户没有给java类定义明确的构造方法的时候,java为我们提供了一个默认的构造方法,这个构造方法没有参数,修饰符是public并且方法体为空。
其实默认的构造方法还分为两种,一种就是刚刚说过的隐藏的构造方法,另一种就是显示定义的默认构造方法。
如果一个类中定义了一个或者多个构造方法,并且每一个构造方法都是带有参数形式的,那么这个类就没有默认的构造方法,看下面的例子。
publicclassSample1{}
publicclassSample2{
publicSample2(inta){System.out.println("
MyConstructor"
);
}
publicclassSample3{
publicSample3(){System.out.println("
MyDefaultConstructor"
上面的三个类中Sample1有一个隐式的默认构造方法,下列语句Sample1s1=newSample()合法;
Sample2没有默认的构造方法,下列语句Sample2s2=newSample2()不合法,执行会编译错误
Sample3有一个显示的默认构造方法,所以以下语句Sample3
s3=newSample3();
合法。
三、实例方法和构造方法中this、super的使用。
"
this"
的用法
实例方法中可以使用this关键字,它指向正在执行方法的类的实例对象,当然static方法中是不可以使用this对象的,因为静态方法不属于类的实例对象;
而构造方法中同样可以使用this关键字,构造器中的this是指向同一个对象中不同参数的另一个构造器。
让我们来看下面的一段代码:
publicclassPlatypus{
Stringname;
Platypus(Stringinput){
name=input;
Platypus(){
this("
John/MaryDoe"
publicstaticvoidmain(Stringargs[]){
Platypusp1=newPlatypus("
digger"
Platypusp2=newPlatypus();
System.out.println(p1.name+"
----"
+p2.name);
上面的代码中类有两个构造器,第一个构造器给类的成员name赋值,第二个构造器调用第一个构造器给类的成员name一个初始值Jonn/MaryDoe
所以程序执行结果:
digger----John/MaryDoe
需要注意的两个地方是:
1、构造方法中通过this关键字调用其他构造方法时,那么这句代码必须放在第一行,否则会编译错误。
2、构造方法中只能通过this调用一次其他的构造方法。
super"
的用法:
实例方法和构造方法中的super关键字都用于去指向父类,实例方法中的super关键字是去调用父类当中的某个方法,看下面的代码:
classgetBirthInfo{
voidgetBirthInfo(){
System.out.println("
bornalive."
classPlatypus1extendsgetBirthInfo
{
hatchfromeggs"
amammalnormallyis"
super.getBirthInfo();
publicclasstest1{
Platypus1p1=newPlatypus1();
p1.getBirthInfo();
上面的例子使用super.getBirthInfo();
调用了它的父类的voidgetBirthInfo()方法。
构造器中使用super关键字调用父类中的构造器,看下面的代码:
getBirthInfo(){
auto"
voidaa(){
Platypus1(){
super();
执行了代码我们就会看到构造器中的super调用了父类的构造方法。
类的继承机制使得子类可以调用父类的功能,下面介绍类在继承关系的初始化顺序问题
请看实例1:
classSuperClass
SuperClass()
SuperClassconstructor"
publicclassSubClassextendsSuperClass{
SubClass()
SubClassconstructor"
SubClasssub=newSubClass();
执行结果:
SuperClassconstructor
SubClassconstructor
代码中我们只实例化子类一个对象,但从执行结果上看程序一开始并不是运行子类的构造方法,而是先执行父类的默认构造方法,然后再执行子类的构造方法。
所以我们在实例化子类对象时,程序会先调用父类的默认构造方法,然后再执行子类的构造方法。
再看实例2:
SuperClass(Stringstr)
Superwithastring."
publicclassSubClassextendsSuperClass
SubClass(Stringstr)
Subwithastring."
publicstaticvoidmain(String[]args)
SubClasssub=newSubClass("
sub"
此程序在JDK下不能编译成功,因为我们在实例化子类对象的时候会先调用其父类默认的构造方法,但是它的父类没有默认的构造方法,所以不能编译成功。
解决办法:
1、在父类中加一个显示的默认构造方法
2、在子类的构造方法中加一句super(str)并且必须在构造器的第一句。
两个办法都可以解决程序编译的问题,但是执行结果是不一样的。
第一种执行结果为:
Subwithastring.
第二种执行结果为:
Superwithastring.
Subwithastring.
第二种方法即使父类中有显示的默认构造方法也不会被调用。
再看实例三:
classOne
One(Stringstr)
System.out.println(str);
classTwo
Oneone_1=newOne("
one-1"
Oneone_2=newOne("
one-2"
Oneone_3=newOne("
one-3"
Two(Stringstr)
publicclassTest
Testmain()start"
Twotwo=newTwo("
two"
Testmain()start
one-1
one-2
one-3
two
我们在main方法中实例了一个Two的对象,但是程序在实例Two对象时并没有先调用Two的构造方法,而是先初始化Two类的成员变量,Two类中有三个成员变量,他们都是One类的对象,所以要依次执行One类的构造方法,然后再初始化Two类的对象。
既在实例化类的对象时,类中的成员变量会首先进行初始化,如果其中的成员变量有对象,那么它们也会按照顺序执行初始化工作。
在所有类成员初始化完成后,才调用对象所在类的构造方法创建对象。
构造方法作用就是初始化。
再看实例四:
staticOneone_3=newOne("
Twotwo_1=newTwo("
two-1"
------------"
Twotwo_2=newTwo("
two-2"
执行结果:
two-1
------------
two-2
结论:
如果一个类中有静态对象,那么他会在非静态对象初始化前进行初始化,但只初始化一次。
而非静态对象每次调用时都要初始化。
再看实例五:
staticTwotwo_3=newTwo("
two-3"
two-3
程序中主类的静态变量会在main()方法执行前初始化。
结果中只输出了一次one-3,这也说明:
如果一个类中有静态对象,那么它会在非静态对象前初始化,但只初始化一次。
非静态对象每次调用时都要初始化。
总结初始化顺序:
1.主类的静态成员首先初始化。
2.主类的父类的构造方法被调用。
3.主类的非静态对象(变量)初始化。
4.调用主类的构造方法。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Java 中的 constructor