Java 构造方法

在 Java 编程中,我们经常需要创建对象并对其进行初始化。构造方法(Constructor)就是专门负责对象初始化的特殊方法。

什么是构造方法?

构造方法是一种特殊的方法,它在创建对象时被自动调用,主要用于初始化对象的成员变量。来看一个简单的例子:

java 复制代码
/*
 * 构造方法:
 *   (1)构造方法的方法名必须和类名一样
 *   (2)构造方法没得返回值,就不能用return返回任何东西,如果要返回,只能返回空
 *  (3)在实例化对象时,构造方法会被自动调用
 *
 * */
public class Demo02 {
    public static void main(String[] args) {
/*        Animal animal = new Animal("xiaobai", 19);
        System.out.println(animal.getName());
        System.out.println(animal.getAge());*/

        Animal ani01 = null;
        ani01 = new Animal("xiaobai", 19);
        Animal ani02 = new Animal("xiaohei", 19);
    }
}

class Animal {
    private String name;
    private int age;

    public Animal(String n, int a) {
        System.out.println("构造方法被调用");
        name = n;
        age = a;
    }


    public void setName(String n) {
        name = n;
    }

    public void setAge(int a) {
        age = a;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    public void say() {
        System.out.println("name = " + name + "; age = " + age);
    }
}

注意事项

  1. 访问修饰符:构造方法可以有访问修饰符(public、private、protected),用于控制对象的创建权限。
  2. 不能被继承 :构造方法不能被子类继承,但子类可以通过super()调用父类的构造方法。
  3. 不能是 abstract、static、final 或 native:这些修饰符与构造方法的特性冲突。
  4. 异常处理:构造方法可以抛出异常,也可以使用 try-catch 处理异常。

总结

构造方法是 Java 面向对象编程中的重要概念,掌握它对于编写健壮的代码至关重要:

  • 构造方法用于初始化对象,在使用new创建对象时自动调用
  • 构造方法名称必须与类名相同,没有返回值类型声明
  • 一个类可以有多个构造方法(重载),提供不同的初始化方式
  • 使用this()可以在构造方法中调用其他构造方法,避免代码重复

通过合理使用构造方法,我们可以确保对象在创建时就处于有效的状态,提高代码的可靠性和可维护性。

相关推荐
kyrie学java1 小时前
SpringWeb
java·开发语言
TTBIGDATA2 小时前
【Hue】Ambari 页面启动 Hue 失败 user ‘hadoop‘ does not exist
java·hadoop·ambari
饺子大魔王的男人3 小时前
Remote JVM Debug+cpolar 让 Java 远程调试超丝滑
java·开发语言·jvm
Hx_Ma1611 小时前
SpringMVC框架提供的转发和重定向
java·开发语言·servlet
期待のcode11 小时前
原子操作类LongAdder
java·开发语言
舟舟亢亢12 小时前
Java集合笔记总结
java·笔记
小酒窝.12 小时前
【多线程】多线程打印ABC
java
乡野码圣13 小时前
【RK3588 Android12】RCU机制
java·jvm·数据库
JAVA+C语言13 小时前
如何优化 Java 多主机通信的性能?
java·开发语言·php
编程彩机14 小时前
互联网大厂Java面试:从分布式架构到大数据场景解析
java·大数据·微服务·spark·kafka·分布式事务·分布式架构