Castle Windsor: Will my transient component be garbage collected?
Asked Answered
C

2

6

Using Castle Windsor, I have a component configured with the transient lifestyle:

<component id="publish.mapping.default"
                   service="IMyService, MyAssembly"
                   type="MyServiceImplementation, Myassembly" 
                   lifestyle="transient" />

Which will be used like this:

var service = container.Resolve<IMyService>(componentId);
// service usage ....
// service goes out of scope ... 

My question is, will the service instance be garbage collected after it goes out of scope, or will Castle Windsor hold on to a reference ? I found this similar question, that implies that the latter might be the case - but after examining the links posted there, I am unsure whether the discussion is about holding on to the reference, or about ensuring that the object are disposed if it implements IDisposable. My objects does not need to be disposed.

If Castle Windsor holds on to the instance, is there any easy way to prevent this (perhaps by configuration) ?

EDIT
It seems, that I need to set the release tracking policy. Can this be configured in the xml config file, or does it need to be set in code ? Can the release tracking policy be set on a per-component basis ?

Complaisance answered 23/2, 2009 at 17:45 Comment(0)
L
9

By default, the container holds a reference to your objects (even the transient ones).

However, as @Bittercoder notes in Why does Castle Windsor hold onto transient objects?, you can change the release tracking policy. It seems that choosing

LifecycledComponentsReleasePolicy:

var policy = container.Kernel.ReleasePolicy;
container.Kernel.ReleasePolicy = LifecycledComponentsReleasePolicy;

But since the question was asked, that appears to have become the default policy.

Lovage answered 23/2, 2009 at 18:9 Comment(4)
Thanks. Do you know whether this can be configured on a per component basis ? (See the edit to my question)Complaisance
I don't think so. I don't actually use Castle (I'd like to), but the docs seem to suggest that it's Kernel-wide. I'm not sure if this is the right thing to do, but it might be possible to add a custom policy that paid attention to your component type...Lovage
The setting of a release policy is container wide. In fact there is documentations that specifies that setting of a release policy is one of the first things that must be done after creating an instance of the container. If this rule is not followed then some of the components will be created using a specific release policy and other using a different. This might result in a high probability of causing memory leaks.Damascus
Page is gone. Can you show an example? (this is why links are bad in answers.)Lovely
N
1

One thing to note is that this seems to have been fixed in the Castle Trunk. In r5475, Hammett changed the default release policy in MicroKernel to LifecycledComponentsReleasePolicy.

Numb answered 25/3, 2009 at 17:40 Comment(2)
Haven't checked the source, but Reflector seems to suggest that this is indeed the case in the DefaultKernel constructor. Handy to know, thanks!Nakashima
So what does this really mean? That the leak shouldn't be a problem with transient?Lovely

© 2022 - 2024 — McMap. All rights reserved.