JVM笔记之运行时数据区域

在这里插入图片描述

1.程序计数器

程序计数器是一块较小的内存区域,他可以看做是当前线程所执行的字节码的行号解释器。

每条线程都会有一个独立的程序计数器,各个线程互不影响,独立存储,这类内存区域叫做线程私有的内存。

2.java虚拟机栈

与程序计数器一样,java虚拟机栈也是线程私有的。

他的生命周期与线程相同。
虚拟机栈描述的是java方法执行的内存模型: 每个方法在执行的时候都会创建一个栈桢,用于存储局部变量表、操作数栈、动态链接、方法出口等,每一个方法从调用直到执行完成的过程,就对应着一个栈桢在虚拟机栈中入栈出栈的过程。
java 内存分为 堆内存 和 栈内存

栈内存(局部变量表)

局部变量表存储的是编译期可知的各种基本类型数据、对象引用类型。
其中64位的long和double类型的数据会占据2个局部变量空间(slot),其余占据一个局部变量空间,。
局部变量表所需内存空间在编译期完成分配。在运行时不会改变局部变量表的大小。

本地方法栈

与虚拟机栈提供的功能是类似的,虚拟机栈为虚拟机执行java方法服务,而本地方法栈则为native方法服务。

3. java堆

java堆是java虚拟机所管理的内存中最大的一块。

java堆是被所有线程共享的一块内存区域。在虚拟机启动的时候创建。

此区域的唯一目的就是存放对象实例、几乎所有的对象实例都在这里创建。
java堆是垃圾收集器管理的主要区域,很多时候也叫做 “GC堆”。
从内存回收的角度讲,由于现在都采用分代收集算法,所以:
java堆中还可以细分为: 新生代 和 老生代

4.方法区

是各个线程共享的内存区域,它用于存储已经被java虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

对方法区的限制非常宽松,除了和java堆一样不需要连续的内存空间和可以选择的固定大小或者可扩展外,还可以选择不实现垃圾收集。
这区域的回收主要针对常量池的回收和对类型的卸载。

5.运行时常量池

运行时常量池是方法区的一部分。
class文件中除了有类的版本、字段、方法、接口等描述信息,还有一项信息是常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。

6.直接内存

就是系统中内存

  • 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 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
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、付费专栏及课程。

余额充值