Garbage Collection in Java
- by simion
On the slides I am revising from it says the following:
  Live objects can be identified either by maintaining a count of the number of references to each object, or by tracing chains of references from the roots.
  
  Reference counting is expensive – it needs action every time a reference changes and it doesn’t spot cyclical structures, but it can reclaim space incrementally.
  
  Tracing involves identifying live objects only when you need to reclaim space – moving the cost from general access to the time at which the GC runs, typically only when you are out of memory.
I understand the principles of why reference counting is expensive but do not understand what 
"doesn’t spot cyclical structures, but it can reclaim space incrementally." means. Could anyone help me out a little bit please?
Thanks