Java -> 构造器,构造方法

构造方法

  我们对封装已经有了基本的了解,接下来我们来看一个新的问题,依然以Person为例,由于Person中的属性都被private了,外界无法直接访问属性,必须对外提供相应的set和get方法。当创建人对象的时候,人对象一创建就要明确其姓名和年龄,那该怎么做呢?

构造方法介绍(构造器)

  在开发中经常需要在创建对象的同时明确对象的属性值,比如员工入职公司就要明确他的姓名、年龄等属性信息。

  那么,创建对象就要明确属性值,那怎么解决呢?也就是在创建对象的时候就要做的事情,当使用new关键字创建对象时,怎么给对象的属性初始化值呢?这  就要学习Java另外一门小技术,构造方法。

  那什么是构造方法呢?从字面上理解即为构建创造时用的方法,即就是对象创建时要执行的方法。既然是对象创建时要执行的方法,那么只要在new对象时,知道其执行的构造方法是什么,就可以在执行这个方法的时候给对象进行属性赋值。

  构造方法的格式:

    修饰符 构造方法名(参数列表)

    {

    }

  构造方法的体现:

  构造方法没有返回值类型。也不需要写返回值。因为它是为构建对象的,对象创建完,方法就执行结束。

  构造方法名称必须和类名保持一致。

  构造方法没有具体的返回值。

  构造方法的代码体现:

  class Person {

   // Person的成员属性age和name

   private int age;

  private String name;

   // Person的构造方法,拥有参数列表

   Person(int a, String nm) {

   // 接受到创建对象时传递进来的值,将值赋给成员属性

   age = a;

   name = nm;

   }

  }

默认构造方法和细节

  1.一个都没有。默认添加无参构造

  2.一个以上,不默认添加无参构造需手动添加

  在没有学习构造方法之前,我们也可以通过new关键字创建对象,并调用相应的方法,同时在描述事物时也没有写构造方法。这是为什么呢?

  在之前学习的过程中,描述事物时,并没有显示指定构造方法,当在编译Java文件时,编译器会自动给class文件中添加默认的构造方法。如果在描述类时,我们显示指定了构造方法,那么,当在编译Java源文件时,编译器就不会再给class文件中添加默认构造方法。

  class Person {

  //如果没有显示指定构造方法,编译会在编译时自动添加默认的构造方法

  //Person(){} //空参数的默认构造方法

  }

  当在描述事物时,要不要在类中写构造方法呢?这时要根据描述事物的特点来确定,当描述的事物在创建其对象时就要明确属性的值,这时就需要在定义类的时候书写带参数的构造方法。若创建对象时不需要明确具体的数据,这时可以不用书写构造方法(不书写也有默认的构造方法)。

  构造方法的细节:

  1、一个类中可以有多个构造方法,多个构造方法是以重载的形式存在的

  2、构造方法是可以被private修饰的,作用:其他程序无法创建该类的对象。

  class Person {

   privateint age;

  private String name;

   // 私有无参数的构造方法,即外界不能通过new Person();语句创建本类对象

   private Person() {

   }

  // 多个构造方法是以重载的形式存在

   Person(int a) {

   age = a;

  }

  Person(String nm, int a) {

   name = nm;

   age = a;

   }

  }

构造方法和一般方法区别

  到目前为止,学习两种方法,分别为构造方法和一般方法,那么他们之间有什么异同呢?

  构造方法在对象创建时就执行了,而且只执行一次。

  一般方法是在对象创建后,需要使用时才被对象调用,并可以被多次调用。

  问题:

    有了构造方法之后可以对对象的属性进行初始化,那么还需要对应的set和get方法吗?

    需要相应的set和get方法,因为对象在创建之后需要修改和访问相应的属性值时,在这时只能通过set或者get方法来操作。

    思考,如下代码有问题吗?

  class Person {

   void Person() {  //构造器没有返回值

   }

  }

  class PersonDemo {

   publicstaticvoid main(String[] args) {

   Person p = new Person();

  }

  }