类加载机制

本文详细介绍了Java类加载的全过程,包括加载、验证、准备、解析和初始化阶段。类加载器按照双亲委派模型工作,确保类的唯一性。在验证阶段,确保字节流的正确性;在准备阶段,分配内存并赋予初始值;解析阶段则将符号引用转为直接引用。类的静态语句块按顺序执行,并且父类的clinit先于子类执行。
摘要由CSDN通过智能技术生成

类加载机制

 

整个生命周期包括加载(loading),验证(verification),准备(preparation),解析(resolution),初始化(initialization),使用(using),卸载(unloading)

加载

虚拟机的规范要求:

  • 根据全限定名加载类的二进制字节流
  • 将静态数据结构转换为方法区的运行时数据结构
  • 生成代表这个类的java.lang.Class对象,作为该类在方法区的结构入口

其中,数组类本身是不通过类加载器加载的,但是数组类的元素类型是通过加载器来完成

验证

保证加载的字节流不会对虚拟机产生破坏,从下面四个方向验证:

  • 文件格式验证:例如魔数,版本,常量池等
  • 元数据验证:类的继承关系等
  • 字节码验证:指令码等信息
  • 符号引用验证:符号引用转直接引用的一些校验

准备

主角先明确一下:类变量(被static修饰的变量),针对主角有两个关键动作:

  • 分配内存
  • 初始值(各类型的0值)

解析

将常量池中的符号引用替换为直接引用的过程,那解析的时机是什么?在操作符号引用的字节码指令之前进行解析,所以就看什么时候会触发那16个指令

  • 类或接口的解析
  • 字段解析
  • 类方法解析
  • 接口方法解析

初始化

真正执行类中定义的Java代码,是执行类构造器<clinit>方法的过程,clinit是由类变量赋值和静态代码块合并产生:

  • 编译器在收集是有顺序的,按照原文件的顺序决定,所以静态语句块只能访问它之前定义的静态变量
  • 父类的clinit会在子类的clinit之前执行,所以父类的静态语句块先执行

类加载器

一个有意思的设计思路,刚才我们看过整个虚拟机加载机制,但对于如何根据全限定名去加载二进制流,jvm将这部分开放了出来,给我们提供了更灵活的设计。

类的唯一性

如果你要是使用instanceOf,Class对象的equals等判断实例是否相等,那需要考虑一下是不是一个类加载器加载的class文件(二进制字节流),因为jvm认为只有类加载器+类全限定名才能确认类的唯一性。

双亲委派

先看一下类加载器吧:

  • 启动类加载器
  • 扩展类加载器
  • 应用程序(系统)类加载器

双亲委派:类加载器收到加载请求时,先把请求让给老爹干,所以所有的活都会最终交给祖宗来干,但是祖宗(老爹)也不傻,每一个加载器都给自己画个圈(比如rt.jar),我就能干这个范围的活,剩下的年轻人自己干吧,上面我们提到了类的唯一性,这样甩锅的方法也有助于确定类的唯一性,否则就乱了;另外,值得注意的是,父加载器和子加载器不是我们想象的继承而是使用的组合模式。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值