博客
关于我
学习中遇到带解决的问题
阅读量:388 次
发布时间:2019-03-05

本文共 968 字,大约阅读时间需要 3 分钟。

对象实例化及JVM装载机制的理解

在Java编程中,对象的实例化过程与JVM的装载机制密切相关。了解这些概念有助于更好地理解程序运行的底层逻辑。

首先,对象实例化是指在内存中创建对象的过程。Java程序在运行时,通过类加载器(Class Loader)将字节码加载到JVM中,并执行类初始化操作。这一过程包括类验证、准备、解析和初始化等阶段。

其次,JVM的装载机制负责将类文件加载到JVM的类路径中。装载器(ClassLoader)在这一过程中,根据类路径查找规则,确定类文件的位置,并读取其字节码。这一机制还支持动态加载,允许程序在运行时动态加载新类。

关于示例中的代码段:

public class InstanceInitTest {{ a = 6; } // 可以省略int修饰符int a = 9;public static void main(String[] args) {System.out.println(new InstanceInitTest().a);}}

其中,类实例化时隐式地初始化字段。即使没有显式声明,JVM会自动为fields进行初始化。默认初始化值的赋值规则是:整数类型默认初始化为0,布尔为false,对象引用为null。

关于FinalErrorTest类的测试:

public class FinalErrorTest {final int age;{System.out.println(age); // 会报错,因为age未被初始化printAge();age = 6;System.out.println(age);}public void printAge() {System.out.println(age);}public static void main(String[] args) {new FinalErrorTest();}}

该测试程序的输出结果为:

06

解释:

  • 在类加载时,age字段被声明为final整数类型,必须在初始化块中初始化。
  • 如果没有对age进行初始化,尝试访问age会导致 NullPointerException。
  • 由于final字段的特殊性,无法在初始化块外重新赋值。
  • 这种设计强制开发者在类初始化时就为final字段初始化,避免了运行时错误。

    转载地址:http://tibwz.baihongyu.com/

    你可能感兴趣的文章
    Oracle学习第五课
    查看>>
    Oracle安装、Navicat for Oracle、JDBCl连接、获取表结构
    查看>>
    ORACLE客户端连接
    查看>>
    oracle常用SQL——创建用户、表空间、授权(12C)
    查看>>
    Oracle数据库异常--- oracle_10g_登录em后,提示java.lang.Exception_Exception_in_sending_Request__null或Connection
    查看>>
    oracle数据库异常---SP2-1503: 无法初始化 Oracle 调用界面 SP2-1503: 无法初始化 Oracle 问题的解决办法
    查看>>
    oracle数据库笔记---oracleweb视图使用流程,及plsql安装
    查看>>
    oracle数据库笔记---pl/sql的基础使用方法
    查看>>
    Transformer 架构解释
    查看>>
    Oracle数据库表空间 数据文件 用户 以及表创建的SQL代码
    查看>>
    oracle数据库零碎---Oracle Merge 使用,表中存在数据就修改,没有数据自动添加
    查看>>
    Oracle数据库验证IMP导入元数据是否会覆盖历史表数据
    查看>>
    Oracle未开启审计情况下追踪表变更记录
    查看>>
    Oracle条件查询
    查看>>
    Oracle查看数据库会话连接
    查看>>
    Oracle查询前几条数据的方法
    查看>>
    oracle树形查询 start with connect by
    查看>>
    oracle毕业论文题目,历届毕业论文申报题目大全.doc
    查看>>
    oracle求助---win7下oracle配置相关疑问Starting Oracle Enterprise Manager 10g Database Control ...发生系统错误 5。
    查看>>
    Oracle流程控制语句
    查看>>