Java 构造函数与修饰符详解:初始化对象与控制权限

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
容器镜像服务 ACR,镜像仓库100个 不限时长
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
简介: Java 构造函数 是一种特殊的类方法,用于在创建对象时初始化对象的属性。它与类名相同,并且没有返回值类型。构造函数的作用:为对象的属性设置初始值执行必要的初始化操作

Java 构造函数

Java 构造函数 是一种特殊的类方法,用于在创建对象时初始化对象的属性。它与类名相同,并且没有返回值类型。

构造函数的作用:

  • 为对象的属性设置初始值
  • 执行必要的初始化操作
  • 提供创建对象的多种方式

构造函数的类型:

  • 默认构造函数: 无参数的构造函数,如果用户没有明确定义构造函数,则 Java 编译器会自动创建一个默认构造函数。
  • 带参数的构造函数: 可以为构造函数添加参数,以便在创建对象时传入初始值。

示例:

public class Main {
   
  int x;

  // 默认构造函数
  public Main() {
   
    x = 5;
  }

  // 带参数的构造函数
  public Main(int y) {
   
    x = y;
  }

  public static void main(String[] args) {
   
    Main myObj1 = new Main(); // 调用默认构造函数
    System.out.println(myObj1.x); // 输出 5

    Main myObj2 = new Main(10); // 调用带参数的构造函数
    System.out.println(myObj2.x); // 输出 10
  }
}

构造函数的注意事项:

  • 构造函数不能被重写。
  • 构造函数不能被声明为 abstract 或 final。
  • 构造函数可以抛出异常。

一些额外的说明:

  • 可以使用构造函数来执行对象的初始化操作,例如:

    • 打开数据库连接
    • 加载配置文件
    • 注册事件监听器
  • 可以使用多个构造函数来提供创建对象的多种方式,例如:

    • 使用默认值创建对象
    • 使用参数创建对象
    • 使用克隆创建对象

Java 修饰符

Java 修饰符 用于控制类、属性、方法和构造函数的访问权限和行为。它们可以分为两组:

  1. 访问修饰符:
  • public: 意味着代码对所有类可访问。
  • private: 意味着代码只能在声明的类内部访问。
  • default: 意味着代码只能在同一包中访问。
  • protected: 意味着代码在同一包和子类中可访问。
  1. 非访问修饰符:
  • final: 意味着类不能被继承,属性和方法不能被重写。
  • static: 意味着属性和方法属于类,而不属于对象。
  • abstract: 意味着类不能用于创建对象,方法没有主体,必须由子类提供。
  • transient: 意味着在序列化包含它们的对象时,属性和方法将被跳过。
  • synchronized: 意味着方法一次只能由一个线程访问。
  • volatile: 意味着属性的值不会在本地线程缓存,总是从“主内存”读取。

示例:

访问修饰符:

// public类可以被任何类访问
public class Main {
   

  // private属性只能在 Main 类内部访问
  private int x = 10;

  // default方法只能在同一个包中访问
  void myMethod() {
   
    System.out.println("This is a default method.");
  }

  // protected方法可以在同一个包和子类中访问
  protected void myProtectedMethod() {
   
    System.out.println("This is a protected method.");
  }

  public static void main(String[] args) {
   
    Main myObj = new Main();
    System.out.println(myObj.x); // 错误,无法访问私有属性
    myObj.myMethod(); // 可以访问 default 方法
    myObj.myProtectedMethod(); // 可以访问 protected 方法
  }
}

非访问修饰符:

public class Main {
   

  // final属性不能被修改
  final int y = 20;

  // static方法可以在不创建对象的情况下访问
  static void myStaticMethod() {
   
    System.out.println("This is a static method.");
  }

  // abstract方法没有主体,必须由子类提供
  abstract void myAbstractMethod();

  public static void main(String[] args) {
   
    // y = 30; // 错误,无法修改 final 属性
    myStaticMethod(); // 可以访问 static 方法
    // myAbstractMethod(); // 错误,无法直接调用抽象方法
  }
}

// 子类继承 Main 类并提供抽象方法的主体
class Child extends Main {
   

  @Override
  void myAbstractMethod() {
   
    System.out.println("This is the implementation of myAbstractMethod.");
  }
}

一些额外的说明:

  • 可以使用多个修饰符来修饰类、属性、方法和构造函数。例如,public final 表示类是公开的并且不能被继承。
  • 修饰符是 Java 语言的重要组成部分,它们可以帮助您控制代码的访问权限和行为。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

相关文章
|
1月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
2月前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
54 17
|
1月前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
1月前
|
Java
Java 静态变量的初始化顺序
【10月更文挑战第15天】了解 Java 静态变量的初始化顺序对于正确编写和维护代码至关重要。通过深入理解初始化顺序的原理和细节,我们可以更好地避免潜在的问题,并提高代码的质量和可靠性。
|
2月前
|
存储 Java 数据管理
Java零基础-Java对象详解
【10月更文挑战第7天】Java零基础教学篇,手把手实践教学!
37 6
|
1月前
|
存储 缓存 NoSQL
一篇搞懂!Java对象序列化与反序列化的底层逻辑
本文介绍了Java中的序列化与反序列化,包括基本概念、应用场景、实现方式及注意事项。序列化是将对象转换为字节流,便于存储和传输;反序列化则是将字节流还原为对象。文中详细讲解了实现序列化的步骤,以及常见的反序列化失败原因和最佳实践。通过实例和代码示例,帮助读者更好地理解和应用这一重要技术。
49 0
|
2月前
|
存储 前端开发 Java
你还没有对象吗?java带你创建一个吧
你还没有对象吗?java带你创建一个吧
25 0
Java反射 - 构造函数
Java反射——构造函数 使用Java反射,您可以检查类的构造函数,并在运行时实例化对象。 这是通过Java类java.lang.reflect.Constructor完成的。
822 0
|
4天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
6天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。