java 查看内存占用大小

简介: 引用:http://www.iteye.com/problems/41631 Java程序计算各种对象所占内存的大小的方法。 基类:  Java代码   public abstract class SizeOf {          private final Runtime s_runtime = Runtime.

引用:http://www.iteye.com/problems/41631

Java程序计算各种对象所占内存的大小的方法。 


基类: 

Java代码 
  收藏代码
  1. public abstract class SizeOf {  
  2.   
  3.     private final Runtime s_runtime = Runtime.getRuntime();  
  4.   
  5.     /** 
  6.      * 
  7.      * 子类负责覆盖该方法以提供被测试类的实例 
  8.      * 
  9.      * @return 被测试类的实例 
  10.      */  
  11.     protected abstract Object newInstance();  
  12.   
  13.     /** 
  14.      * 
  15.      * 计算实例的大小(字节数) 
  16.      * 
  17.      * @return 实例所占内存的字节数 
  18.      * @throws Exception 
  19.      */  
  20.     public int size() throws Exception {  
  21.   
  22.         // 垃圾回收  
  23.         runGC();  
  24.   
  25.         // 提供尽可能多(10万)的实例以使计算结果更精确  
  26.         final int count = 100000;  
  27.         Object[] objects = new Object[count];  
  28.   
  29.         // 实例化前堆已使用大小  
  30.         long heap1 = usedMemory();  
  31.         // 多实例化一个对象  
  32.         for (int i = -1; i < count; ++i) {  
  33.             Object object = null;  
  34.   
  35.             // 实例化对象  
  36.             object = newInstance();  
  37.   
  38.             if (i >= 0) {  
  39.                 objects[i] = object;  
  40.             } else {  
  41.                 // 释放第一个对象  
  42.                 object = null;  
  43.                 // 垃圾收集  
  44.                 runGC();  
  45.                 // 实例化之前堆已使用大小  
  46.                 heap1 = usedMemory();  
  47.             }  
  48.         }  
  49.   
  50.         runGC();  
  51.         // 实例化之后堆已使用大小  
  52.         long heap2 = usedMemory();  
  53.         final int size = Math.round(((float) (heap2 - heap1)) / count);  
  54.   
  55.         // 释放内存  
  56.         for (int i = 0; i < count; ++i) {  
  57.             objects[i] = null;  
  58.         }  
  59.         objects = null;  
  60.         return size;  
  61.     }  
  62.   
  63.     private void runGC() throws Exception {  
  64.         // 执行多次以使内存收集更有效  
  65.         for (int r = 0; r < 4; ++r) {  
  66.             _runGC();  
  67.         }  
  68.     }  
  69.   
  70.     private void _runGC() throws Exception {  
  71.         long usedMem1 = usedMemory();  
  72.         long usedMem2 = Long.MAX_VALUE;  
  73.         for (int i = 0; (usedMem1 < usedMem2) && (i < 500); ++i) {  
  74.             s_runtime.runFinalization();  
  75.             s_runtime.gc();  
  76.             Thread.currentThread().yield();  
  77.             usedMem2 = usedMem1;  
  78.             usedMem1 = usedMemory();  
  79.         }  
  80.     }  
  81.   
  82.     /** 
  83.      * 
  84.      * 堆中已使用内存 
  85.      * 
  86.      * @return 堆中已使用内存 
  87.      */  
  88.     private long usedMemory() {  
  89.         return s_runtime.totalMemory() - s_runtime.freeMemory();  
  90.     }  
  91. }  



子类: 

Java代码 
  收藏代码
  1. public class SizeOfObject extends SizeOf {  
  2.   
  3.     @Override  
  4.     protected Object newInstance() {  
  5.         return new Object();  
  6.     }  
  7.   
  8.     public static void main(String[] args) throws Exception {  
  9.         SizeOf sizeOf = new SizeOfObject();  
  10.         System.out.println("所占内存:" + sizeOf.size() + "字节");  
  11.     }  
  12. }  




输出为:所占内存:8字节 

利用序列化(Serializable)计算对象的大小 
下面代码可以计算session的大小: 
将session中的所有对象输出到文件中,文件的大小就是对象的大小. 

Java代码 
  收藏代码
  1. try {  
  2.     FileOutputStream f = new FileOutputStream("c:/sessionFiles");  
  3.     ObjectOutputStream s = new ObjectOutputStream(f);  
  4.     s.writeObject("session:");  
  5.     HttpSession session = request.getSession(false);  
  6.     Enumeration names = session.getAttributeNames();  
  7.     while(names.hasMoreElements()){  
  8.         s.writeObject(session.getAttribute((String) names.nextElement()));  
  9.     }  
  10.     s.flush();  
  11.     s.close();  
  12.     f.close();  
  13. catch (Exception e) {  
  14.     e.printStackTrace();  
  15. }  



也可以看看这个 


java对象占内存大小 

http://329937021.iteye.com/blog/547779 

相关文章
|
5月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
652 3
|
6月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
4月前
|
Java 大数据 Go
从混沌到秩序:Java共享内存模型如何通过显式约束驯服并发?
并发编程旨在混乱中建立秩序。本文对比Java共享内存模型与Golang消息传递模型,剖析显式同步与隐式因果的哲学差异,揭示happens-before等机制如何保障内存可见性与数据一致性,展现两大范式的深层分野。(238字)
139 4
|
4月前
|
存储 缓存 Java
【深入浅出】揭秘Java内存模型(JMM):并发编程的基石
本文深入解析Java内存模型(JMM),揭示synchronized与volatile的底层原理,剖析主内存与工作内存、可见性、有序性等核心概念,助你理解并发编程三大难题及Happens-Before、内存屏障等解决方案,掌握多线程编程基石。
|
9月前
|
存储 缓存 Java
【高薪程序员必看】万字长文拆解Java并发编程!(5):深入理解JMM:Java内存模型的三大特性与volatile底层原理
JMM,Java Memory Model,Java内存模型,定义了主内存,工作内存,确保Java在不同平台上的正确运行主内存Main Memory:所有线程共享的内存区域,所有的变量都存储在主存中工作内存Working Memory:每个线程拥有自己的工作内存,用于保存变量的副本.线程执行过程中先将主内存中的变量读到工作内存中,对变量进行操作之后再将变量写入主内存,jvm概念说明主内存所有线程共享的内存区域,存储原始变量(堆内存中的对象实例和静态变量)工作内存。
291 0
|
5月前
|
缓存 监控 Kubernetes
Java虚拟机内存溢出(Java Heap Space)问题处理方案
综上所述, 解决Java Heap Space溢出需从多角度综合施策; 包括但不限于配置调整、代码审查与优化以及系统设计层面改进; 同样也不能忽视运行期监控与预警设置之重要性; 及早发现潜在风险点并采取相应补救手段至关重要.
793 17
|
6月前
|
监控 Kubernetes Java
最新技术栈驱动的 Java 绿色计算与性能优化实操指南涵盖内存优化与能效提升实战技巧
本文介绍了基于Java 24+技术栈的绿色计算与性能优化实操指南。主要内容包括:1)JVM调优,如分代ZGC配置和结构化并发优化;2)代码级优化,包括向量API加速数据处理和零拷贝I/O;3)容器化环境优化,如K8s资源匹配和节能模式配置;4)监控分析工具使用。通过实践表明,这些优化能显著提升性能(响应时间降低40-60%)同时降低资源消耗(内存减少30-50%,CPU降低20-40%)和能耗(服务器功耗减少15-35%)。建议采用渐进式优化策略。
328 1
|
7月前
|
SQL 缓存 安全
深度理解 Java 内存模型:从并发基石到实践应用
本文深入解析 Java 内存模型(JMM),涵盖其在并发编程中的核心作用与实践应用。内容包括 JMM 解决的可见性、原子性和有序性问题,线程与内存的交互机制,volatile、synchronized 和 happens-before 等关键机制的使用,以及在单例模式、线程通信等场景中的实战案例。同时,还介绍了常见并发 Bug 的排查与解决方案,帮助开发者写出高效、线程安全的 Java 程序。
422 0
|
6月前
|
存储 监控 算法
Java垃圾回收机制(GC)与内存模型
本文主要讲述JVM的内存模型和基本调优机制。