1. JAVA的构造函数是怎么写的
JAVA的构造函数是:SetLocal EnableDelayedExpansion
set classpath=.
for %%c in (lib\*.jar) do set classpath=!classpath!;%%c
set classpath=%classpath%;./classes;
java com.ham.server.Server。
1、无参构造方法
无参构造方法又分为隐式无参构造方法和显示无参构造方法。
隐式无参构造方法
在定义类的时候,如果没有给类定义一个构造方法,Java编译器在编译时会默认提供一个隐式的构造方法,它没有任何参数,并且有一个空的方法体。例如,Person类中隐含一个无参构造方法,在main方法中可以通过new关键字来调用此默认的构造方法,代码如下:
2、显式无参构造方法
隐式无参构造方法是由系统提供的,无法修改其内容。但有时需要在调用这个构造方法时初始化类成员属性或执行一些操作,要实现这个需求,就需要为它定义一个显式无参构造方法,修改上述代码如下:
3、显示有参构造方法
构造并初始化对象是构造方法的作用,所以有时需要给这个方法传入一些参数,定义一个显示的有参构造方法。例如:
2. Java中构造函数是什么
是构造方法,不是构造函数,后者是C++的概念首先要注意的是Java的构造器并不是函数,所以他并不能被继承,这在我们extends的时候写子类的构造器时比较的常见,即使子类构造器参数和父类的完全一样,我们也要写super就是因为这个原因。
构造器的修饰符比较的有限,仅仅只有public private protected这三个,其他的例如任何修饰符都不能对其使用,也就是说构造器不允许被成名成抽象、同步、静态等等访问限制以外的形式。 因为构造器不是函数,所以它是没有返回值的,也不允许有返回值。
但是这里要说明一下,构造器中允许存在return语句,但是return什么都不返回,如果你指定了返回值,虽然编译器不会报出任何错误,但是JVM会认为他是一个与构造器同名的函数罢了,这样就会出现一些莫名其妙的无法找到构造器的错误,这里是要加倍注意的。 在我们extends一个子类的时候经常会出现一些意想不到的问题,我在这里说一些和构造器有关的。
首先说一下Java在构造实例时的顺序(不讨论装载类的过程) 构造的粗略过程如下 1、分配对象空间,并将对象中成员初始化为0或者空,java不允许用户操纵一个不定值的对象。 2、执行属性值的显式初始化(这里有一点变化,一会解释,但大体是这样的) 3、执行构造器 4、将变量关联到堆中的对象上 介绍一下准备知识,以备一会来详细说明这个的流程 this() super()是你如果想用传入当前构造器中的参数或者构造器中的数据调用其他构造器或者控制父类构造器时使用的,在一个构造器中你只能使用this()或者super()之中的一个,而且调用的位置只能在构造器的第一行, 在子类中如果你希望调用父类的构造器来初始化父类的部分,那就用合适的参数来调用super(),如果你用没有参数的super()来调用父类的构造器(同时也没有使用this()来调用其他构造器),父类缺省的构造器会被调用,如果父类没有缺省的构造器,那编译器就会报一个错误,注意此处,我们经常在继承父类的时候构造器中并不写和父类有关的内容,此时如果父类没有缺省构造器,就会出现编译器添加的缺省构造器给你添麻烦的问题了哦。
例如:Class b extends a{public b(){}}就没有任何有关父类构造器的信息,这时父类的缺省构造器就会被调用。 举个SL-275中的例子 1 public class Manager extends Employee { 2 private String department; 3 4 public Manager(String name, double salary, String dept) { 5 super(name, salary); 6 department = dept; 7 } 8 public Manager(String n, String dept) { 9 super(name); 10 department = dept; 11 } 12 public Manager(String dept) { // 这里就没有super(),编译器会自动地添加一个空参数的缺省super构造器,此时如果Employee类中没有空参数的缺省构造器,那就会导致一个编译错误 13 department = d; 14 } 15 } 你必须在构造器的第一行放置super或者this构造器,否则编译器会自动地放一个空参数的super构造器的,其他的构造器也可以调用super或者this,调用成一个递归构造链,最后的结果是父类的构造器(可能有多级父类构造器)始终在子类的构造器之前执行,递归的调用父类构造器 在具体构造类实例的过程中,上边过程的第二步和第三步是有一些变化的,这里的顺序是这样的,分配了对象空间及对象成员初始化为默认值之后,构造器就递归的从继承树由根部向下调用,每个构造器的执行过程是这样的: 1、Bind构造器的参数 2、如果显式的调用了this,那就递归调用this构造器然后跳到步骤5 3、递归调用显式或者隐式的父类构造器,除了Object以外,因为它没有父类 4、执行显式的实例变量初始化(也就是上边的流程中的第二步,调用返回以后执行,这个步骤相当于在父构造器执行后隐含执行的,看样子像一个特殊处理) 5、执行构造器的其它部分 这里的步骤很重要哦!!!!! 从这个步骤中可以很明显的发现这个实例初始化时的递归调用过程,估计看过这个你应该能够理解这个递归构造链是怎么样回事了。
这里还是给出SL-275中的一个例子,让你充分理解一下这个递归的过程。 public class Object { 。
public Object() {} 。 } public class Employee extends Object { private String name; private double salary = 15000.00; private Date birthDate; public Employee(String n, Date DoB) { // implicit super(); name = n; birthDate = DoB; } public Employee(String n) { this(n, null); } } public class Manager extends Employee { private String department; public Manager(String n, String d) { super(n); department = d; } } 在创建Manager("Joe Smith","Sales"):时,步骤如下 0 basic initialization 0.1 allocate memory for the complete Manager object 0.2 initialize all instance variables to their default values (0 or null) 1 call constructor: Manager("Joe Smith", "Sales") 1.1 bind constructor parameters: n="Joe Smith", d="Sales" 1.2 no explicit this() call 1.3 call super(n) for Employee(String) 1.3.1 bind constructor parameters: n="Joe Smith" 1.3.2 call this(n, null) for Employee(String, Date) 1.3.2.1 bind constructor 。
3. JAVA里面的构造函数到底该怎么理解
其实很简单,JAVA是一种面向对象的语言,所有的数据都是以对象的形式存在的,构造函数保证你在new一个对象的时候,它里面的数据被正确的赋值。比如:
class A{
int a;
public A(){}; //无参数的构造函数 数据A被赋值为0.
public A(int a){ this.a = a}; //有参数的构造方法,你可以在创建对象的时候主对
//a 赋值
}
A m = new A();
A n = new A(10);
转载请注明出处育才学习网 » java构造函数怎么写