一、打包和使用方法参考我之前的这篇文章,本文主要是更新了测量的类及方法,实际测试这个方法更准确。

https://www.cnblogs.com/yoyotl/p/8421287.html

二、新的测量类

//package net.sourceforge.sizeof;

import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.lang.instrument.Instrumentation;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.IdentityHashMap;
import java.util.Map; public class SizeOf {
private static OutputStream out = System.out;
private static Instrumentation inst;
private static long MIN_CLASS_SIZE_TO_LOG = 1048576L;
private static boolean SKIP_STATIC_FIELD = false;
private static boolean SKIP_FINAL_FIELD = false;
private static boolean SKIP_FLYWEIGHT_FIELD = false;
private static boolean debug = false;
private static String[] unit = {"b", "Kb", "Mb", "Gb", "Tb"}; public static void premain(String paramString, Instrumentation paramInstrumentation) {
inst = paramInstrumentation;
System.out.println("JAVAGENT: call premain instrumentation for class SizeOf");
} public static long sizeOf(Object paramObject) {
if (inst == null) {
throw new IllegalStateException("Instrumentation is null");
}
if ((SKIP_FLYWEIGHT_FIELD) && (isSharedFlyweight(paramObject))) {
return 0L;
}
return inst.getObjectSize(paramObject);
} public static String humanReadable(long paramLong) {
double d = paramLong;
int i = ;
for (i = ; (i < ) && (d >= 1024.0D); i++) {
d /= 1024.0D;
}
return d + unit[i];
} public static long deepSizeOf(Object paramObject) {
IdentityHashMap localIdentityHashMap = new IdentityHashMap();
return deepSizeOf(paramObject, localIdentityHashMap, );
} /**
* @deprecated
*/
public static long iterativeSizeOf(Object paramObject)
throws IllegalArgumentException, IllegalAccessException, IOException {
return deepSizeOf(paramObject);
} private static String indent(int paramInt) {
StringBuilder localStringBuilder = new StringBuilder();
for (int i = ; i < paramInt; i++) {
localStringBuilder.append(" ");
}
return localStringBuilder.toString();
} private static long deepSizeOf(Object paramObject, Map<Object, Object> paramMap, int paramInt) {
if (paramObject == null) {
if (debug) {
print("null\n");
}
return 0L;
}
long l = 0L;
if (paramMap.containsKey(paramObject)) {
if (debug) {
print("\n%s{ yet computed }\n", new Object[]{indent(paramInt)});
}
return 0L;
}
if (debug) {
print("\n%s{ %s\n", new Object[]{indent(paramInt), paramObject.getClass().getName()});
}
paramMap.put(paramObject, null);
l = sizeOf(paramObject);
if ((paramObject instanceof Object[])) {
int i = ;
for (Object localObject2 : (Object[]) paramObject) {
if (debug) {
print("%s [%d] = ", new Object[]{indent(paramInt), Integer.valueOf(i++)});
}
l += deepSizeOf(localObject2, paramMap, paramInt + );
}
} else {
Field[] arrayOfField = paramObject.getClass().getDeclaredFields();
for (Object localObject2 : arrayOfField) {
((Field) localObject2).setAccessible(true);
Object localObject3;
try {
localObject3 = ((Field) localObject2).get(paramObject);
} catch (IllegalArgumentException localIllegalArgumentException) {
throw new RuntimeException(localIllegalArgumentException);
} catch (IllegalAccessException localIllegalAccessException) {
throw new RuntimeException(localIllegalAccessException);
}
if (isComputable((Field) localObject2)) {
if (debug) {
print("%s %s = ", new Object[]{indent(paramInt), ((Field) localObject2).getName()});
}
l += deepSizeOf(localObject3, paramMap, paramInt + );
} else if (debug) {
print("%s %s = %s\n", new Object[]{indent(paramInt), ((Field) localObject2).getName(), localObject3.toString()});
}
}
}
if (debug) {
print("%s} size = %s\n", new Object[]{indent(paramInt), humanReadable(l)});
}
if ((MIN_CLASS_SIZE_TO_LOG > 0L) && (l >= MIN_CLASS_SIZE_TO_LOG)) {
print("Found big object: %s%s@%s size: %s\n", new Object[]{indent(paramInt), paramObject.getClass().getName(), Integer.valueOf(System.identityHashCode(paramObject)), humanReadable(l)});
}
return l;
} private static boolean isAPrimitiveType(Class paramClass) {
if (paramClass == Boolean.TYPE) {
return true;
}
if (paramClass == Character.TYPE) {
return true;
}
if (paramClass == Byte.TYPE) {
return true;
}
if (paramClass == Short.TYPE) {
return true;
}
if (paramClass == Integer.TYPE) {
return true;
}
if (paramClass == Long.TYPE) {
return true;
}
if (paramClass == Float.TYPE) {
return true;
}
if (paramClass == Double.TYPE) {
return true;
}
return paramClass == Void.TYPE;
} private static boolean isComputable(Field paramField) {
int i = paramField.getModifiers();
if (isAPrimitiveType(paramField.getType())) {
return false;
}
if ((SKIP_STATIC_FIELD) && (Modifier.isStatic(i))) {
return false;
}
return (!SKIP_FINAL_FIELD) || (!Modifier.isFinal(i));
} private static boolean isSharedFlyweight(Object paramObject) {
if ((paramObject instanceof Comparable)) {
if ((paramObject instanceof Enum)) {
return true;
}
if ((paramObject instanceof String)) {
return paramObject == ((String) paramObject).intern();
}
if ((paramObject instanceof Boolean)) {
return (paramObject == Boolean.TRUE) || (paramObject == Boolean.FALSE);
}
if ((paramObject instanceof Integer)) {
return paramObject == Integer.valueOf(((Integer) paramObject).intValue());
}
if ((paramObject instanceof Short)) {
return paramObject == Short.valueOf(((Short) paramObject).shortValue());
}
if ((paramObject instanceof Byte)) {
return paramObject == Byte.valueOf(((Byte) paramObject).byteValue());
}
if ((paramObject instanceof Long)) {
return paramObject == Long.valueOf(((Long) paramObject).longValue());
}
if ((paramObject instanceof Character)) {
return paramObject == Character.valueOf(((Character) paramObject).charValue());
}
}
return false;
} public static void setMinSizeToLog(long paramLong) {
MIN_CLASS_SIZE_TO_LOG = paramLong;
} public static void skipFinalField(boolean paramBoolean) {
SKIP_FINAL_FIELD = paramBoolean;
} public static void skipStaticField(boolean paramBoolean) {
SKIP_STATIC_FIELD = paramBoolean;
} public static void skipFlyweightObject(boolean paramBoolean) {
SKIP_FLYWEIGHT_FIELD = paramBoolean;
} private static void print(String paramString) {
try {
out.write(paramString.getBytes());
} catch (IOException localIOException) {
throw new RuntimeException(localIOException);
}
} private static void print(String paramString, Object... paramVarArgs) {
try {
out.write(String.format(paramString, paramVarArgs).getBytes());
} catch (IOException localIOException) {
throw new RuntimeException(localIOException);
}
} public static void setLogOutputStream(OutputStream paramOutputStream) {
if (paramOutputStream == null) {
throw new IllegalArgumentException("Can't use a null OutputStream");
}
out = paramOutputStream;
} public static void turnOnDebug() {
debug = true;
} public static void turnOffDebug() {
debug = false;
}
}

PS:反编译一个开源测试库并优化代码得到的新类,测试有效,希望对你有用。

Java对象的内存实际占用的更多相关文章

  1. java对象在内存的大小

    前言 一直以来,对java对象大小的概念停留在基础数据类型,比如byte占1字节,int占4字节,long占8字节等,但是一个对象包含的内存空间肯定不只有这些. 假设有类A和B,当new A()或者n ...

  2. Java对象的内存模型(一)

    前言 新人一枚,刚刚入门编程不久,各方面都在学习当中,博文有什么错误的地方,希望我们可以多多交流! 最近,在开发App后台过程中,需要将项目部署到云服务器上.而云服务器的内存大小却只有1G.要如何做到 ...

  3. Java对象的内存布局

    对象的内存布局 平时用java编写程序,你了解java对象的内存布局么? 在HotSpot虚拟机中,对象在内存中存储的布局可以分为3块区域: 对象头 实例数据 对齐填充 对象头 对象头包括两部分信息: ...

  4. JVM总结-java对象的内存布局

    在 Java 程序中,我们拥有多种新建对象的方式.除了最为常见的 new 语句之外,我们还可以通过反射机制.Object.clone 方法.反序列化以及 Unsafe.allocateInstance ...

  5. Java对象的内存(一)

    前言 新人一枚,刚刚入门编程不久,各方面都在学习当中,博文有什么错误的地方,希望我们可以多多交流! 最近,在开发App后台过程中,需要将项目部署到云服务器上.而云服务器的内存大小却只有1G.要如何做到 ...

  6. java对象在内存中的分配

    java对象在内存中的分配 http://blog.csdn.net/qq_30753945/article/details/54974899

  7. 10 Java 对象的内存布局

    Java 创建对象的方式 1:new 语句和反射机制创建.该方式会调用类的构造器,同时满足诸多约束.如果一个类没有构造器的话,Java 编译器会自动添加一个无参数的构造器.子类的构造器需要调用父类的构 ...

  8. Java对象的内存布局以及对象的访问定位

    一 Java对象的内存布局 在HotSpot虚拟机中,对象在内存中的布局分为3个区域 对象头(Header) Mark Word(在32bit和64bit虚拟机上长度分别为32bit和64bit)存储 ...

  9. 3 Java对象的内存布局以及对象的访问定位

    先来看看Java对象在内存中的布局   一 Java对象的内存布局 在HotSpot虚拟机中,对象在内存中的布局分为3个区域 对象头(Header) Mark Word(在32bit和64bit虚拟机 ...

随机推荐

  1. java基础面试题-2

    第一,谈谈final, finally, finalize的区别.  final---修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此一个类不能既被 ...

  2. <构建之法>阅读笔记6

    第九章:项目经理 是讲项目经理的作用功能和重要性,书里面主要讲的是微软的PM(Programe Manager)和其他团队PM(Project Manager)的区别,还介绍了PM的能力要求以及人物, ...

  3. 063 日志分析(pv  uv  登录人数  游客人数  平均访问时间  二跳率  独立IP)

    1.需求分析 分析指标 pv uv 登录人数 游客人数 平均访问时间 二跳率 独立IP 2.使用的日志(一号店),会话信息 3.创建数据库 4.创建源表,存储源数据 5.创建我们需要的use表 6.创 ...

  4. 026 使用大数据对网站基本指标PV案例的分析

    案例: 使用电商网站的用户行为日志进行统计分析 一:准备 1.指标 PV:网页流浪量 UV:独立访客数 VV:访客的访问数,session次数 IP:独立的IP数 2.上传测试数据 3.查看第一条记录 ...

  5. C++对文本文件的读取和输出

    本文转载自xmh_free 自己浏览了上方的博客,主要整理了一下关于C++对文件的输入输出方法,如果想看C语言的输入输出方法,可浏览上述链接的博客 C++读写函数 在C++中,对文件的操作是通过str ...

  6. Couple number

    P1348 Couple number 我其实找规律了的,然后也没仔细分析,这个题多巧妙. C=a^2-b^2=(a+b)(a-b) 对于任意a而言,加减同一个数得到的数的奇偶性相同,故c=奇数或4的 ...

  7. 004.Kickstart部署之FTP架构

    一 准备 1.1 完整架构:Kickstart+DHCP+VSFTP+TFTP+PXE 1.2 组件应用 Kickstart服务端IP:172.24.8.12 DHCP:提供客户端IP,网关,镜像路径 ...

  8. 【jvm】来自于线上的fullGC分析

    系统最近老年代的内存上升的比较快,三到四天会发生一波fullGC.于是开始对GC的情况做一波分析. 线上老年代2.7G,年轻带1.3G老年代上升较快,3天一波fullGC,并且fullGC会把内存回收 ...

  9. win10搭建tensorflow-gpu环境

    昨天辛苦的配了GPU环境,记录一下防止以后还需要用到. 我配GPU的目的是用tensorflow的gpu来加速 不用ubuntu是因为一来不习惯,二来我不会配ubuntu的扩展显示器,就更不习惯了,习 ...

  10. ACM差分约束笔记

    https://www.cnblogs.com/31415926535x/p/10463112.html 很早之前学最短路的时候就看了一眼差分约束,,当时以为这种问题不怎么会出现,,而且当时为了只为了 ...