首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java学习笔记——内存管理Java内存管理

Java内存管理 简介 Java虚拟机的内存管理分为以下几个运行时数据区: 方法区 堆 虚拟机栈 本地方法栈 程序计数器 其中,方法区和堆是所有线程共享的数据区,而其他的是线程隔离的数据区。...堆 Java堆,又称GC堆,是GC的管理的主要区域。在虚拟机启动时创建。主要作用是存放对象实例,几乎所有的对象实例都会存放在Java堆中。Java堆可以处于物理不连续的内存空间中,只要逻辑连续即可。...通常Java堆是可扩展的。当Java堆无法申请到所需的内存空间来存放实例,也无法扩展时,会抛出,OutOfMemoryError异常。...---- 虚拟机栈 Java虚拟机栈是线程私有的,它的生命周期与线程相同。虚拟机栈是Java方法执行的内存模型。每个方法在执行的同时会创建一个栈帧。...服务器管理员配置虚拟机参数时,一般会根据实际内存设置-Xmx等参数信息,但经常会忽略掉直接内存,使得各个内存区域的总和大于物理内存限制(包括物理上的和操作系统级的限制),从而导致动态扩展时出现OutOfMemoryError

1.4K30

java内存管理

java虚拟机在应用在执行的过程中将自己管理内存分为5部分: 方法区,堆,虚拟机栈,本地方法栈,程序计数器 程序计数器:是线程私有的 表示代码执行到哪里,通过改变这个计数器的值来选取下一条需要执行的字节码指令...,该内存是唯一一个不会发生内存溢出的地方如果线程正在执行的是一个Java方法,这个计数器记录的是正在执行的虚拟机字节码指令的地址;如果正在执行的是Native方法,这个计数器值则为空(Undefined...本地方法栈:略 堆:堆内存是我们比较关心的,它是gc的主要区域,是线程共享的,此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存Java堆中还可以细分为:新生代和老年代;再细致一点的有...假设Java堆中内存是绝对规整的,所有用过的内存都放在一边,空闲的内存放在另一边,中间放着一个指针作为分界点的指示器,那所分配内存就仅仅是把那个指针向空闲空间那边挪动一段与对象大小相等的距离,这种分配方式称为...如果Java堆中的内存并不是规整的,已使用的内存和空闲的内存相互交错,那就没有办法简单地进行指针碰撞了,虚拟机就必须维护一个列表,记录上哪些内存块是可用的,在分配的时候从列表中找到一块足够大的空间划分给对象实例

49320
您找到你想要的搜索结果了吗?
是的
没有找到

Java内存管理

不过看了一遍《深入Java虚拟机》再来理解Java内存管理会好很多。接下来一起学习下Java内存管理吧。...1、方法区(Method Area) 方法区(Method Area)与Java堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。...虽然Java虚拟机规范把方法区描述为堆的一个逻辑部分,但是它却有一个别名叫做Non-Heap(非堆),目的应该是与Java堆区分开来。...下面重点解下Java内存管理中的栈和堆。 3、栈(Stacks) 在Java中,JVM中的栈记录了线程的方法调用。每个线程拥有一个栈。...垃圾回收是Java的一大特征。并不是所有的语言都有垃圾回收功能。比如在C/C++中,并没有垃圾回收的机制。程序员需要手动释放堆中的内存。 由于不需要手动释放内存,程序员在编程中也可以减少犯错的机会。

44130

Java内存管理

RD自己的单测一路畅通,QA构造的复杂测试case果断报StackOverflowError 理论学习 简单复习一下,虚拟机运行时管理内存分为图中这几部分 这里写图片描述 程序计数器:存储当前线程执行字节码指令地址...理论上,无法申请到足够内存时,也会抛出OutOfMemoryError。64位jdk7下默认大小为1024字节。 Heap堆:对象都分配在堆上,这部分是垃圾回收管理的主要区域。...Direct Memory直接内存:不在JVM中,Nio中的DirectByteBuffer对象通过引用Native堆中内存,避免Java堆和Native堆内存复制的方式来提升性能。...如果这部分内存加上Java内存大于服务器物理内存限制,也会导致JVM出现OOM。...jconsole基于jmx进行监控和管理,已经很好用了;jvisualvm比jconsole要新一些,功能也更强大,不仅包含了大部分命令行工具具备的功能,还能通过插件机制扩展性能,比如profiing性能分析等

1.6K50

Java内存缓存-通过Map定制简单缓存

为什么要用缓存 ? 场景 在Java应用中,对于访问频率高,更新少的数据,通常的方案是将这类数据加入缓存中,相对从数据库中读取,读缓存效率会有很大提升。...方案 基于JSR107规范自研 基于ConcurrentHashMap实现数据缓存 JSR107规范目标 为应用程序提供缓存Java对象的功能。 定义了一套通用的缓存概念和工具。...CacheManager定义了创建、配置、获取、管理和控制多个唯一命名的Cache,这些Cache存在于- CacheManager的上下文中。...小例子 使用Map来实现一个简单的缓存功能 MapCacheDemo.java package me.xueyao.cache.java; import java.lang.ref.SoftReference...* 我使用SoftReference 作为映射值,因为软引用可以保证在抛出OutOfMemory之前,如果缺少内存,将删除引用的对象。

3.5K41

Java内存管理(一、内存分配)

一、Java内存分配 1、 Java有几种存储区域?...3、Java内存模型 * Java虚拟机将其管辖的内存大致分三个逻辑部分:方法区(Method Area)、Java栈和Java堆。    ...-- Java堆分配(heap allocation)意味着以随意的顺序,在运行时进行存储空间分配和收回的内存管理模型。         堆中存储的数据常常是大小、数量和生命期在编译时无法确定的。...堆是在 Java虚拟机启动时创建的。”      可以看出JVM主要管理两种类型的内存:堆和非堆。     ...简单来说堆就是Java代码可及的内存,是留给开发人员使用的;      非堆就是JVM留给自己用的,所以方法区、JVM内部处理或优化所需的内存(如JIT编译后的代码缓存)、每个类结构(如运行时常数池、

3.4K30

系统内存管理:虚拟内存内存分段与分页、页表缓存TLB以及Linux内存管理

这样,进程可以以一种透明的方式访问内存,无需关心内存的实际物理位置。通过虚拟内存机制,操作系统能够更好地管理系统内存资源,提供更高的安全性和稳定性。...页表缓存TLB(Translation Lookaside Buffer)TLB(Translation Lookaside Buffer)是一个位于CPU芯片中的缓存,用于存储程序中最常访问的页表项,...然而,由于程序的局部性原理,程序执行期间通常仅限于某一部分,访问的存储空间也局限于某个内存区域。因此,通过将最常访问的页表项存储到TLB这个硬件缓存中,可以更快地进行地址转换。...Linux内存管理Linux内存管理涉及逻辑地址和线性地址的转换。逻辑地址是程序使用的地址,而线性地址是通过段式内存管理映射的地址,也称为虚拟地址。...虚拟内存的实现方式有分段和分页,其中分页机制更为常用,采用多级页表的方式节约了内存空间。页表缓存TLB能够加快虚拟地址到物理地址的转换速度。

43180

java内存管理(上)

一.简介 可以分几部分回答这个问题,首先JVM内存划分 | JVM垃圾回收的含义  |  有哪些GC算法  以及年轻代和老年代各自特点等等。...二.java内存划分 方法区 (线程共享)  常量  静态变量  JIT(即时编译器)编译后代码也在方法区存放 堆内存(线程共享) 垃圾回收的主要场地 程序计数器  当前线程执行的字节码的位置指示器 Java...虚拟机栈(栈内存) :保存局部变量,基本数据类型以及堆内存中对象的引用变量 本地方法栈  (C栈):为JVM提供使用native方法的服务 通过这幅图了解一下 JDK 1.8同JDK 1.7 最大的区别是...生命周期:随着线程的创建而创建,随着线程的销毁而销毁 是一个唯一不会出现的OutOfMemoryError的内存区域 Java虚拟机栈 定义: 描述Java方法运行过程的内存模型 Java虚拟机栈会为每一个即将运行的...Java虚拟机栈的最大深度是,就会抛出此异常 OutOFMemoryError,若允许动态扩展,那么当前线程的请求的栈内存用完了,无法再动态扩展时,抛出此异常 Java虚拟机栈也是线程私有,随着线程创建而创建

67110

java内存管理(下)

,可以向常量池中添加新的常量,如String类的intern()方法就能在运行期间向常量池中添加字符串常量 直接内存(堆外内存) 直接内存是除Java虚拟机之外的内存,但有可能被Java使用 操作直接内存...: 在NIO中引入了一种基于通道和缓存的IO方式,他可以调用本地方法的直接分配Java虚拟机之外的内存,然后通过一个存储在堆中的DirectByteBuffer对象直接操作该内存,而无需将外部内存中数据复制到堆中再进行操作...,从而提高数据操作的效率,直接内存的大小不受Java虚拟机,也会抛出OutOfMemoryError异常 ** 直接内存和堆内存比较:** 直接内存申请空间耗费更高的性能 直接内存读取IO的性能优于普通的堆内存...直接内存的作用链:本地IO–>直接内存–>本地IO 堆内存的作用链:本地IO–>直接内存–>非直接内存–>直接内存—>本地IO 服务器管理员在配置虚拟机参数时,会根据实际内存设置 -Xmx等参数信息,...对象的堆内存由成为垃圾回收器的自动内存管理系统回收 非堆内存分配: ①:JVM使用-XX:PermSize 设置非堆内存的初始值,默认物理内存的1/64; ② :由XX:MaxPermSize设置设置最大非堆内存的大小

33610

Java自动内存管理

一、Java内存区域 为了方便管理和程序执行,Java虚拟机所管理内存包括以下几个部分:程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区。...Java虚拟机栈:Java方法执行的内存模型,每个方法从调用到执行完毕,就对应一个栈帧在虚拟机栈中入栈到出栈的过程。线程私有。...Java堆:存放对象实例,几乎所有对象实例都在堆中分配。线程共享。 方法区:用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据。线程共享。...但是Java领域都没有使用引用计数法来管理内存,主要原因是这个看似简单的算法有很多例外的情况要考虑,必须要配合大量额外处理才能保证正确的工作,比如单纯的引用计数法就很难解决对象之间相互循环引用的问题。...可达性分析算法 主流商用程序语言的内存管理子系统都是通过可达性分析算法来判断对象是否存活的。

47210

JVM内存管理------JAVA语言的内存管理概述

引言 内存管理一直是Java语言自豪与骄傲的资本,它让JAVA程序员基本上可以彻底忽略与内存管理相关的细节,只专注于业务逻辑。...它与JAVA堆的区别除了存储的信息与JAVA堆不一样之外,最大的区别就是这一部分JAVA虚拟机规范不强制要求实现自动内存管理系统(GC)。...内存管理 内存管理分为内存分配和内存释放,看一下上面的五个内存区域,其实可以大致分为两部分,一部分是全局共享,一部分是线程独有。...这一部分内存,不需要垃圾搜集器的管理,而是JAVA虚拟机来主动管理,每当一个线程被创建的时候,JAVA虚拟机就会为其分配相应的PC寄存器和JAVA虚拟机栈,如果需要的话,还会有本地方法栈。...而这部分内存的释放,则是由自动内存管理系统(以下简称GC)来管理的。 通常情况下,堆内存分配是要依赖于GC的策略与实现的,在分配的时候,就要考虑好到时候如何回收这部分内存

88970

Caffeine缓存 最快缓存 内存缓存

使用Caffeine后无需使用Guava Cache,从并发的角度来讲,Caffeine明显优于Guava,原因是使用了Java 8最新的StampedLock锁技术。...2、进程关系 缓存 进程关系 备注 Redis 与业务进程独立,由操作系统独立管理,业务系统重启对缓存服务无影响 Redis服务与业务服务独立,互相影响较小 EhCache 附着于业务进程,业务系统重启...,存储与内存部分的缓存数据丢失;存储与硬盘部分的数据继续存在 缓存配置存在两种模式:一种是纯内存型,一种是可持久化到磁盘 Caffeine 附着于业务进程,业务系统重启,缓存数据全部丢失 纯内存内存缓存的理解...:缓存都是使用内存作为存储媒介的,各种缓存服务的区别如下:Caffeine是内存缓存是指缓存与调用者属于同一个应用,准确的说属于同一个JVM;Redis是指另外一个独立进程的内存型,缓存数据存储在Redis...spring: cache:   type: caffeine 3、缓存管理器 配置缓存管理器:多CacheName配置。

2.9K30

如何使用Java进行缓存管理

缓存管理是在计算机领域中普遍的一项技术,它可以将一些常用的数据、文件或者对象存储到内存中,以提高程序的性能和响应速度。Java作为一种流行的编程语言,在缓存管理方面也提供了许多工具和类库。...下面将简要介绍如何使用Java进行缓存管理。 一、Java Cache API Java SE 6及以上版本提供了一个专门用于缓存管理的API,即Java Cache API。...= Caching.getCachingProvider(); CacheManager cacheManager = provider.getCacheManager(); 有了缓存管理器之后,我们就可以使用缓存的操作了...我们可以设置缓存项的类型、失效策略、统计信息等。然后通过缓存管理器来创建一个名称为myCache的缓存实例,并向其中添加了一个键值对。最后,我们从缓存中获取了key对应的value。...二、Spring Cache Spring是Java世界中非常流行的开发框架,它提供了一种便捷的缓存管理方式——Spring Cache。

14210

Java内存管理原理及内存区域详解

一、概述 Java虚拟机在执行Java程序的过程中会把它所管理内存划分为若干不同的数据区域,这些区域都有各自的用途以及创建和销毁的时间。...Java虚拟机所管理内存将会包括以下几个运行时数据区域,如下图所示: ? 下面就每一个区域进行阐述。 二、运行时数据区域 程序计数器 程序计数器,可以看做是当前线程所执行的字节码的行号指示器。...JavaJava堆是所有线程共享的一块内存区域,在虚拟机启动时创建,此内存区域的唯一目的就是存放对象实例 。 Java堆是垃圾收集器管理的主要区域。...直接内存的分配不会受到Java堆大小的限制,但是会受到本机内存大小的限制,所有也可能会抛OutOfMemoryError异常。...类加载检查通过后,虚拟机将为新生对象分配内存。为对象分配空间的任务等同于把一块确定大小的内存Java堆中划分出来。

63310

Java内存管理原理及内存区域详解

一、概述 Java虚拟机在执行Java程序的过程中会把它所管理内存划分为若干不同的数据区域,这些区域都有各自的用途以及创建和销毁的时间。...Java虚拟机所管理内存将会包括以下几个运行时数据区域,如下图所示: ? 下面就每一个区域进行阐述。 二、运行时数据区域 程序计数器 程序计数器,可以看做是当前线程所执行的字节码的行号指示器。...JavaJava堆是所有线程共享的一块内存区域,在虚拟机启动时创建,此内存区域的唯一目的就是存放对象实例 。 Java堆是垃圾收集器管理的主要区域。...直接内存的分配不会受到Java堆大小的限制,但是会受到本机内存大小的限制,所有也可能会抛OutOfMemoryError异常。...类加载检查通过后,虚拟机将为新生对象分配内存。为对象分配空间的任务等同于把一块确定大小的内存Java堆中划分出来。

44510

Java内存管理(二、Java垃圾回收)

二、Java垃圾回收 1. JVM运行环境中垃圾对象的定义      一个对象创建后被放置在JVM的堆内存中,当永远不再引用这个对象时,它将被JVM在堆内存中回收。...    -- 执行构造方法体 * 应用阶段     -- 特征:系统至少维护着对象的一个强引用;所有对该对象引用强引用(除非显示声明为其它引用)     -- 强引用       指JVM内存管理器从根引用集合出发...Java中提供软引用的包:java.lang.ref.SoftReference(后续详解)      软引用       实现cache功能,防止最大限度的使用内存时引起的OutOfMemory异常...WeakHashMap能够节约存储空间,可用 来缓存那些非必须存在的数据。  ...WeakHashMap能够节约存储空间,可用 来缓存那些非必须存在的数据。

44710

【Linux 内核 内存管理内存管理架构 ③ ( Linux 内核中的内存管理模块 | 页分配器 | 不连续页分配器 | 内存控制组 | 硬件设备内存管理 | MMU | 页表缓存 | 高速缓存 )

文章目录 一、Linux 内核中的内存管理模块 二、硬件设备内存管理 一、Linux 内核中的内存管理模块 ---- Linux 内核还需要处理如下内容 : ① 页错误异常处理 ② 页表管理 ③ 引导内存分配器...: 控制管理 被 进程 占用的 内存 ; 碎片整理 : 如果 " 内存碎片化 " 严重 , 没有连续物理页 , 需要通过 整理内存碎片 并迁移数据 得到 连续的 物理页 ; 内存回收 : 内存不足时 ,...回收内存 ; ⑦ 页回收处理 二、硬件设备内存管理 ---- 硬件设备内存管理 : ① CPU 处理器 中的 " 内存管理单元 " ( MMU ) 和 高速缓存 ; ② 物理内存 在 " 内存管理单元..." ( MMU ) 中 , 还有一个 " 页表缓存 " ; 页表缓存缓存了 最近使用的 " 页表映射 “ , 该映射的作用是 将 ” 物理地址 " 映射为 " 虚拟地址 " ; CPU 处理器...与 内存 访问速度不匹配 , 增加了 " 高速缓存 " 机制 ; 一级缓存 : 数据缓存 , 指令缓存 ; 二级缓存 : 协调 内存 与 一级缓存 ;

1.4K40

JAVA线程-CPU缓存内存屏障(四)

上节说了线程中止,优雅和暴力的方式,也说到了通过标志位的方式,这次一起说说CPU缓存内存屏障。 ?...CPU 告诉缓存,硬盘很慢,运用缓存加载到内存里面,提高的访问速度,尽可能地避免处理器访问主内存的时间开销,处理器大多会一用缓存(cache)以提高性能。...⑤ CPU高速缓存和CPU执行指令重排序的问题 1.缓存中的数据与主内存的数据并不是实时同步的, 各CPU间缓存的数据也不是实时同步....⑥ 解决CPU告诉缓存和CPU质量重排序的问题 1.写内存屏障(Store Memory Barrier): 在指令后插入Store Barrier, 能让写入缓存中的最新数据更新写入主内存, 让其他线程可见强制写入主内存...2.读内存屏障(Load Memory Barrier): 在指令前插入Load Barrier, 可以让高速缓存中的数据失效, 强制从新从主内存读取数据强制读取主内存内容, 让CPU缓存和主内存保持一致

1.8K10
领券