Skip to main content

Java is Disappointing Sometimes...

What's Java's number one problem?  If you said "efficiency," then you win!  Why do we still use C and C++?  If you said "efficiency," then you also win!

And so... yesterday, we learned about templates and generics and so forth, and I was able to ask a question that's been bugging me for quite some time.  "When you declare an ArrayList<Integer>, are Integer Objects being stored internally, or are primitive ints being stored?"

Prior to yesterday, I had given this quite a bit of thought, actually.  I'd say about a year ago, I determined that since the classes like Integer, Byte, Float were final, non-inheritable classes, that Java could actually optimize the language by artificially storing primitive ints, auto-unboxing and auto-boxing them, as appropriate.  But, as it turned out, I was wrong!

Java does not do that.  Instead, when you store a bunch of "primitive ints" in an ArrayList<Integer>, what actually happens is that the ints are wrapped by Integer Objects, and the Integer Objects are essentially up-casted to Object internally and stored in the ArrayList.  Then, when you grab something from the ArrayList, it is essentially down-casted to Integer again, and converted back to a primitive int, if necessary.  This solution provides backward compatibility, but it is VERY inefficient.

Observe...
If I have a normal Java array of int of 10,000 elements...
int[] foo = new int[10000];
The memory allocated here is (10,000 elements) * (4 bytes per element) + 16 byte array overhead = 40016 bytes
The array has a length (integer), and you should also count the pointer to the array, etc.

If I have an ArrayList<Integer> of 10,000 Integer Objects...
ArrayList<Integer> foo = new ArrayList<Integer> (10000);
The memory allocated here is (8 bytes for Object) + (4 bytes for 32-bit pointer to actual array) + (4 bytes for "size" variable) + (16 bytes of array overhead) + (4 bytes from parent class instance variable -- another size) + (4 bytes of crap overhead -- don't ask) + (4 bytes per Object reference * 10000 elements) = 40040 bytes... all to store null Integer Object references.  If you actually place integers into the ArrayList, then each Integer Object will take up 16 bytes -- (8 bytes for Object) + (4 bytes for int inside Object) + (4 bytes of crap overhead).  So, if you actually fill that ArrayList<Integer> with data, you will use 200,040 bytes.  That's roughly FIVE times more than what was really required!!

NOT TO MENTION THE ADDITIONAL INEFFICIENCY OF AUTO-BOXING/UNBOXING AND DE-REFERENCING THAT ACTUALLY GOES ON BEHIND THE SCENES!

So why is Java slow?  Hmm... disappointing.

Comments

Popular posts from this blog

Beware the Ides of March...in 9 days

Stupid heading for this blog, but whatever.  I was amused.   So, a lot has happened since my last entry, which I believe was sometime in January.  I have officially started a new business -- OnlineFixShop, LLC.  The web address is http://www.onlinefixshop.com/ .  Check it out!  For the next few months, my business will be focusing on home PC repair.     I am offering services that can help you:   Rid your computer of spyware and viruses Retrieve lost information and data Gain access to the Internet Increase your computer's performance and speed Learn your way around various types of software Setup a secure wireless or wired network Back-up personal and valuable data Secure your computer(s) and protect your data Eventually, I am planning to focus on repairing computers over the Internet using remote administration technology, which I have yet to design.   Right now, I am working to setup an onlin...

JavaScript Sticky Footer and Scroll Effect

This post talks about two different HTML/JavaScript effects: How to keep a page footer stuck at the bottom of the browser window. How to create a scrolling <div> without using a scroll bar OK. So... you have a website. You want a header stuck at the top of your page and the footer stuck at the bottom of your page. The stuff in the middle, you want to be able to scrollable. But, you don't want those ugly scrollbars to the right of your scrollable text. Maybe, instead, you'll have up arrows and down arrows above and below your <div>. When you mouseover the arrows, the text in the <div> will move up or down and create a scrolling effect. Suppose your page looks like this... <html> <head> <title>Test</title> </head> <body> <div style="position: relative; width: 700px; margin-left: auto; margin-right: auto;"> <div id="header">Header</div> <div id="scrollUp...

Today's Quote

This is simply a brain dump.  I'm sleepy, and I want to type out some of the thoughts currently in my head. "Luck is where preparation and opportunity meet."  This is so remarkably true, and today I'm making it a mantra.  I believe that luck is merely an illusion that we perceive, but it truly when we have prepared ourselves for the right opportunity... and then a great opportunity comes along.  Many great opportunities pass us by every day.  Once we begin to recognize them and prepare for them, then we start to experience the thrill of luck. Interestingly, as described in "Good to Great", Mr. James Collins talks about how "Level 5" leaders often attribute their great success to luck .  That's a humble way of saying, "I planned on taking advantage of every opportunity ."   Hmmm...