Sign in to follow this  
rockseller

Java game Garbage Collection

Recommended Posts

rockseller    121
When initializing the game, I do create temporary objects for X reasons.

When the game is ready for the main update loop, there is a series of small hiccups, that doesn't last much.

What is the best approach to eliminate these hiccups?

I was thinking in a black screen that would last X seconds once the main update loop is readt, this way the GC would enter (I hope) before I let the user play.

What do you think?

Share this post


Link to post
Share on other sites
I don't think the black screen is a good idea. At the initialization of the game you should load alll [b]necessary [/b]objects that you will need. Then, depending on the game, you could use a cache system to access to your preloaded objects which should eliminate hiccups if you do it right. If you have to load objects at runtime, you can load it into the cache and then always access it from there. Though, you need to release objects that you don't need anymore from the cache afterward.

And by "cache" I don't mean anything complicated. It can be a hashmap of objects with names as key.

Think about it, if you have hiccups it's surely because you are loading something at each loop pass.

Share this post


Link to post
Share on other sites
wqking    761
You should avoid frequently allocate/free objects, e.g, allocate a lot of objects in each frame.
Instead, allocate some objects before entering the level and reuse them until the level is finished. That's some kind of "cache" or "pool".
Also, check if you have a lot of string "add" operation. S3 = S1 + S2 will cause dynamic memory allocation, IMO.

Share this post


Link to post
Share on other sites
fae    214
Have you already analysed that the delay is really caused by Java garbage collection? If not, I'd really recommend analysing the problem more thoroughly before committing to any changes. There are lots of other possible causes for such delays when presenting game data to the end user, e.g. preparing the graphics context, establishing and initialising buffers in an OpenGL application etc. However we can't really speculate on these as we don't know what type of an application you have and what libraries and frameworks you're using.

Depending on the environment and SDK you could already have a suitable tool for analysing this, see [url="http://docs.oracle.com/javase/6/docs/technotes/guides/visualvm/intro.html"]http://docs.oracle.com/javase/6/docs/technotes/guides/visualvm/intro.html[/url] and [url="http://docs.oracle.com/javase/6/docs/technotes/guides/management/jconsole.html"]http://docs.oracle.com/javase/6/docs/technotes/guides/management/jconsole.html[/url].

IF the problem really is with GC, the recommendations above are really good. Other viable solution could be explicitly calling System.gc after the init is done. This basically asks the system to perform GC (note that it doesn't force it, the JVM is free to ignore the request). Depending on the situation this could prevent the GC from happening during the actual game logic. However the other approaches highlighted above are usually more appropriate as they limit any further GCs during the game.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

Sign in to follow this