前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >基础篇:详解JAVA对象实例化过程

基础篇:详解JAVA对象实例化过程

作者头像
潜行前行
发布于 2020-12-11 08:02:34
发布于 2020-12-11 08:02:34
2K0
举报
文章被收录于专栏:潜行前行潜行前行

1 对象的实例化过程

  • 对象的实例化过程是分成两部分:类的加载初始化,对象的初始化
  • 要创建类的对象实例需要先加载并初始化该类,main方法所在的类需要先加载和初始化
  • 类初始化就是执行<clinit>方法,对象实例化是执行<init>方法
  • 一个子类要初始化需要先初始化父类

2 类的加载过程

  • 类的加载机制:如果没有相应类的class,则加载class到方法区。对应着加载->验证->准备->解析-->初始化阶段
    • 加载:载入class对象,不一定是从class文件获取,可以是jar包,或者动态生成的class
    • 验证:校验class字节流是否符合当前jvm规范
    • 准备:为类变量分配内存并设置变量的初始值(默认值)。如果是final修饰的对象则是赋值声明值
    • 解析:将常量池的符号引用替换为直接引用
    • 初始化:执行类构造器<client>(注意不是对象构造器),为类变量赋值,执行静态代码块。jvm会保证子类的<client>执行之前,父类的<client>先执行完毕
  • 其中验证、准备、解析3个部分称为 连接
  • <clinit>方法由静态变量赋值代码和静态代码块组成;先执行类静态变量显示赋值代码,再到静态代码块代码

3 触发类加载的条件

  • 第一次创建类的新对象时,会触发类的加载初始化和对象的初始化函数<init>执行,这个是实例初始化,其他6个都是类初始化
  • JVM启动时会先加载初始化包含main方法的类
  • 调用类的静态方法(如执行invokestatic指令)
  • 对类或接口的静态字段执行读写操作(即执行getstatic、putstatic指令);不过final修饰的静态字段的除外(已经赋值,String和基本类型,不包含包装类型),它被初始化为一个编译时常量表达式
    • 注意:操作静态字段时,只有直接定义这个字段的类才会被初始化;如通过其子类来操作父类中定义的静态字段,只会触发父类<clinit>的初始化而不是子类的初始化
  • 调用JavaAPI中的反射方法时(比调用java.lang.Class中的方法(Class.forName),或者java.lang.reflect包中其他类的方法)
  • 当初始化一个类时,其父类没有初始化,则需先触发父类的初始化(接口例外)

4 对象的实例化过程

  • 对象实例化过程 其实就是执行类构造函数 对应在字节码文件中的<init>()方法(称之为实例构造器);<init>()方法由非静态变量、非静态代码块以及对应的构造器组成
    • <init>()方法可以重载多个,类有几个构造器就有几个<init>()方法
    • <init>()方法中的代码执行顺序为:父类变量初始化,父类代码块,父类构造器,子类变量初始化,子类代码块,子类构造器。
  • 静态变量,静态代码块,普通变量,普通代码块,构造器的执行顺序
  • 具有父类的子类的实例化顺序如下

5 类加载器和双亲委派规则,如何打破双亲委派规则

  • 类加载器
    • 通过一个类的全限定名来获取描述此类的二进制字节流,实现这个动作的代码模块称为类加载器
    • 任意一个类都需要其加载器和类本身来确定类在JVM的唯一性;每个类加载器都有自己的类名称空间,同一个类class由不同的加载器加载,则被JVM判断为不同的类
  • 双亲委派模型
    • 启动类加载器有C++代码实现,是虚拟机的一部分。负责加载\lib下的类库
    • 其他的类加载器有java语言实现,独立于JVM,并且继承ClassLoader
    • extention ClassLoader负责加载\lib\ext目录下的类库
    • application ClassLoader 负责加载用户路径下(ClassPath)的代码
    • 不同的类加载器加载同一个class文件会导致出现两个类。而java给出解决方法是下层的加载器加委托上级的加载器去加载类,如果父类无法加载(在自己负责的目录找不到对应的类),而交还下层类加载器去加载。如下图
  • 打破双亲委派模型
    • 双亲委派模型并不是一个强制的约束模型,而是java设计者推荐给开发者的类加载实现方式
    • 双亲委派模型很好的解决各个类加载基础类的同一问题(越基础的类由越上层的加载器加载),但是基础类总是作为用户代码调用的API,但是如果它的具体实现是下层的代码,此时基础类需要调用下层的代码,则需要打破双亲委派模型
    • 如JNDI服务,JNDI的代码有启动类去加载(rt.jar),它需要调用由独立厂商部署在应用程序classpath下的JNDI的SPI(Service Provider Interface)代码。为了解决SPI代码加载问题,java引入了线程上下文类加载器去加载SPI代码。也就是父类加载器请求子类去完成类的加载动作
    • 线程上下文类加载器,线程创建时会从父线程继承,如果全局范围没有设置过,则默认设置为application Class Loader

6 题外话:JarEntry和JavaUtilJarAccess使用


欢迎指正文中错误

关注公众号,一起交流

参考文章

  • 对象实例化过程
  • java对象的实例化过程
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-09-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 潜行前行 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
Java 中事务的应用
在企业级应用开发中,事务是确保数据完整性和一致性的关键机制。Java 提供了丰富的事务处理能力,通过合理地运用事务,可以有效地避免数据在并发操作或系统故障时出现不一致的情况。本文将深入探讨 Java 中事务的概念、原理、应用场景以及如何在不同的环境中使用事务来保障数据的正确性和可靠性。
编程小白狼
2024/12/31
880
【Java 进阶篇】MySQL 事务详解
在数据库管理中,事务是一组SQL语句的执行单元,它们被视为一个整体。事务的主要目标是保持数据库的一致性和完整性,即要么所有SQL语句都成功执行,要么所有SQL语句都不执行。在MySQL中,事务起到了非常重要的作用,特别是在需要确保数据的完整性和一致性的应用程序中。
繁依Fanyi
2023/10/12
2960
【Java 进阶篇】MySQL 事务详解
Go 语言中的 MySQL 事务操作
在现代应用程序中,数据的完整性和一致性至关重要。MySQL 的事务功能提供了一种确保操作安全且可靠的机制。
南山竹
2024/08/13
910
Go 语言中的 MySQL 事务操作
事务处理
如果在第一条SQL语句执行成功后,在执行第二条SQL语句之前,程序被中断了(可能是抛出了某个异常,也可能是其他什么原因),那么李四的账户没有加上100元,而张三却减去了100元。这肯定是不行的!
星哥玩云
2022/09/14
5180
数据库事务与并发处理
在现代应用程序中,数据库事务和并发处理是确保数据一致性和系统稳定性的核心技术。理解这些概念和实现方法是开发健壮系统的基础。本篇博客将详细讲解数据库事务的原理、并发处理的常见问题以及最佳实践,帮助开发者深入掌握相关知识。
繁依Fanyi
2025/01/27
1650
JDBC中事务回滚
 理解:防止出现未知错误,导致原先要执行完全的数据只执行了一半,最终影响数据,也就是 事务是一组组合成逻辑工作单元的操作,虽然系统中可能会出错,但事务将控制和维护事务中每个操作的一致性和完整性。
吃猫的鱼Code
2023/02/02
1.7K0
MySQL·事务
事务指的是满足 ACID 特性的一组操作,可以通过 Commit 提交一个事务,也可以使用 Rollback 进行回滚。
数媒派
2022/12/01
1.9K0
深入解析 GBase 数据库的事务处理与一致性保障
随着现代业务场景对数据库需求的不断升级,高并发事务处理与数据一致性已成为数据库性能的关键指标。GBase 系列数据库(如 GBase8s 和 GBase8c)因其卓越的事务处理能力与一致性保障机制,成为众多企业级应用的核心支柱。
用户11381600
2024/12/03
1590
Spring JDBC-Spring事务管理之数据库事务基础知识
在使用Spring开发应用时,Spring的事务管理可能是被使用最多、应用最广的功能。 Spring不但提供了和底层事务源无关的事务抽象,还提供了声明性事务的功能,可以让开发者从事务代码中解放出来。
小小工匠
2021/08/17
4280
java核心技术第五篇之事务和MVC模式
第一部分:事务 1.事务的简介: 1.1 在一组操作中(比如增加操作,修改操作),只有增加和修改操作都成功之后,这两个操作才能真正的成功. ,如果这两个操作中,有一个失败了,这两个操作都失败了.
海仔
2019/08/05
6650
MySQL中的事务隔离级别是什么,提供一个使用事务的实际案例
MySQL中的事务隔离级别是指在并发访问数据库时,事务之间相互隔离的程度。MySQL提供了四种标准的事务隔离级别,分别是读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。不同的隔离级别对于数据库的并发性、一致性和性能有不同的影响。
用户1289394
2024/06/11
1810
MySQL中的事务隔离级别是什么,提供一个使用事务的实际案例
【数据库】MySQL:ACID特性、隔离级别及实战操作
MySQL 中的事务是数据库管理系统中用来确保多个 SQL 操作以原子性的方式执行的机制。事务可以保证一系列操作要么全部成功,要么全部失败,从而保证数据库的一致性和完整性。
易辰君
2024/11/07
2740
JDBC事务控制管理
今天是学习计划的第二天,感觉自己的学习热情还是很高涨的啊,那我们就趁热打铁,开始今天的学习。 今天的学习内容是JDBC的事务控制管理。 首先是概念性的内容 事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部不成功。这是我对于事务的理解。 举个例子: A转账给B,对应如下的两条sql语句 update from account set money = money - 100 where name = ‘A’ update from account set money = money + 100 where name = ‘B’ 在现实生活中,这两条sql语句要么就应该同时成功,要么就应该同时失败,否则用户的账户就会产生问题。 在MySQL数据库中,默认情况下,一条sql语句就是一个单独的事务,事务是自动提交的 在Oracle数据库中,默认情况下,事务不是自动提交的,所有sql语句都处于一个事务中,需要手动进行事务提交。 数据库事务命令
wangweijun
2020/02/13
1.2K0
深入探索Java开发世界:MySQL~类型分析大揭秘
忆愿
2025/01/12
990
深入探索Java开发世界:MySQL~类型分析大揭秘
SQL事务
COMMIT是指提交事务,即试图把事务内的所有SQL所做的修改永久保存。如果COMMIT语句执行失败了,整个事务也会失败。
Autooooooo
2020/11/09
4170
数据库事务
如果在执行一个业务操作的时候,需要执行多条SQL语句,必须保证所有的SQL语句都执行成功。只要其中有一条执行失败,则所有的SQL语句都要进行回滚
Devops海洋的渔夫
2021/03/12
7360
数据库事务
MySQL基础之事务编程学习笔记
在学习《MySQL技术内幕:SQL编程》一书,并做了笔记。本博客内容是自己学了《MySQL技术内幕:SQL编程》事务编程一章之后,根据自己的理解做的笔记,内容和书本并不一致,不过书本实验都经过自己验证,基于MySQL5.7版本。做笔记的目的是方便自己复习,同时分享出来或许对其他人或许有点帮助
SmileNicky
2020/01/13
4830
MySQL基础之事务编程学习笔记
MySQL显式事务与隐式事务
显式事务是指在应用程序中明确指定事务的开始和结束,使用BEGIN、COMMIT和ROLLBACK语句来控制事务的执行。
堕落飞鸟
2023/05/11
1.3K0
2025年新出炉的MySQL面试题
该问题的重点在于理解MySQL XA事务的概念、特性以及其在分布式系统中的应用。面试者需要能够清晰地阐述XA事务的全局事务管理器(GTM)和局部资源管理器(LRM)的角色,以及XA事务的启动、执行、分支事务的提交和回滚等阶段。此外,面试者还需要展示如何在MySQL中使用XA事务,并能够解释代码中的每一步操作。
小白的大数据之旅
2025/01/20
1090
12. JDBC事务的处理 以及 转账案例
上一章节,我已经写了一篇数据库事务的章节。篇幅比较长,基本让我们知道了数据库事务操作、隔离级别等等知识。那么本章节我们再简化一下内容,再快速过一下事务处理 和 转账案例,加深印象。
Devops海洋的渔夫
2022/01/17
2970
12. JDBC事务的处理 以及 转账案例
相关推荐
Java 中事务的应用
更多 >
LV.1
这个人很懒,什么都没有留下~
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档