?
Solved

Java Object Size in Memory

Posted on 2011-03-02
7
Medium Priority
?
400 Views
Last Modified: 2012-05-11
I'm trying to determine how much heap memory is allocated for a java object (Object type could be List, String, Array, Map etc) in Web environment. I could not use Instrumentation package in web environment since I can not run javaAgent over there. Is there any way find object size in bytes in multi threading environment?
0
Comment
Question by:MatrixStar
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
7 Comments
 
LVL 47

Expert Comment

by:for_yan
ID: 35021145
0
 

Author Comment

by:MatrixStar
ID: 35021805
Yes, I had looked at Instrumentation way of doing and not the other one. I will try using reflection. But, there is no other API or classes, is it?
0
 
LVL 47

Expert Comment

by:for_yan
ID: 35021865


I don't know about API, but there aslo some other things there - which are neither
Instrumentation nor Reflection, like this code based on creating and deleteing
object and measuraing garbage collection paparmeters - don't know how practical,
at least sounds interesting


http://stackoverflow.com/posts/757400/edit


A good generic solution is to use heap size delta.  This involves minimal effort and is re-usable between any type of object / object graph.  By instantiating and destroying your objects many times and garbage collecting in between, and then taking the average, you avoid compiler and JVM optimizations that alter results and get a fairly accurate result.  If you need an EXACT answer down to the byte then this may not be the solution for you, but for all practical applications that I know of (profiling, memory requirement calcualtions) it works extremely well.  The code below will do just that.
 

		public class Sizeof {
		  public static void main(String[] args)
			  throws Exception {
			// "warm up" all classes/methods that we are going to use:
			runGC();
			usedMemory();
		
			// array to keep strong references to allocated objects:
			final int count = 10000; // 10000 or so is enough for small ojects
			Object[] objects = new Object[count];
		
			long heap1 = 0;
		
			// allocate count+1 objects, discard the first one:
			for (int i = -1; i < count; ++i) {
			  Object object;
		
		//// INSTANTIATE YOUR DATA HERE AND ASSIGN IT TO 'object':
				
		
			  object=YOUR OBJECT;
		////end your code here
			  if (i >= 0) {
				objects[i] = object;
			  }
			  else {
				object = null; // discard the "warmup" object
				runGC();
				heap1 = usedMemory(); // take a "before" heap snapshot
			  }
			}
		
			runGC();
			long heap2 = usedMemory(); // take an "after" heap snapshot:
		
			final int size = Math.round(((float)(heap2 - heap1)) / count);
			System.out.println("'before' heap: " + heap1 +
							   ", 'after' heap: " + heap2);
			System.out.println("heap delta: " + (heap2 - heap1) +
							   ", {" + objects[0].getClass() + "} size = " + size + " bytes");
		  }
		
		  // a helper method for creating Strings of desired length
		  // and avoiding getting tricked by String interning:
		  public static String createString(final int length) {
			final char[] result = new char[length];
			for (int i = 0; i < length; ++i) {
			  result[i] = (char)i;
			}
		
			return new String(result);
		  }
		
		  // this is our way of requesting garbage collection to be run:
		  // [how aggressive it is depends on the JVM to a large degree, but
		  // it is almost always better than a single Runtime.gc() call]
		  private static void runGC()
			  throws Exception {
			// for whatever reason it helps to call Runtime.gc()
			// using several method calls:
			for (int r = 0; r < 4; ++r) {
			  _runGC();
			}
		  }
		
		  private static void _runGC()
			  throws Exception {
			long usedMem1 = usedMemory(), usedMem2 = Long.MAX_VALUE;
		
			for (int i = 0; (usedMem1 < usedMem2) && (i < 1000); ++i) {
			  s_runtime.runFinalization();
			  s_runtime.gc();
			  Thread.currentThread().yield();
		
			  usedMem2 = usedMem1;
			  usedMem1 = usedMemory();
			}
		  }
		
		  private static long usedMemory() {
			return s_runtime.totalMemory() - s_runtime.freeMemory();
		  }
		
		  private static final Runtime s_runtime = Runtime.getRuntime();
		
		} // end of class

Open in new window

0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 92

Accepted Solution

by:
objects earned 2000 total points
ID: 35022499
there is no api, and all the methods people use just give an approximation.
0
 

Author Comment

by:MatrixStar
ID: 35022774
Thanks, I don't think, this will work well in multi threading environment.
0
 
LVL 60

Expert Comment

by:Kevin Cross
ID: 36935145
This question has been classified as abandoned and is closed as part of the Cleanup Program. See the recommendation for more details.
0

Featured Post

Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Are you developing a Java application and want to create Excel Spreadsheets? You have come to the right place, this article will describe how you can create Excel Spreadsheets from a Java Application. For the purposes of this article, I will be u…
Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
Video by: Michael
Viewers learn about how to reduce the potential repetitiveness of coding in main by developing methods to perform specific tasks for their program. Additionally, objects are introduced for the purpose of learning how to call methods in Java. Define …
This theoretical tutorial explains exceptions, reasons for exceptions, different categories of exception and exception hierarchy.
Suggested Courses

649 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question