Is there any way to determine in which AppDomain was an object or ObjectHandle instance created?
-
Good question, but I suspect the answer is no :( – leppie May 29 '12 at 17:20
2 Answers
If your object "travelled" using (e.g.) serialization from another AppDomain to the current AppDomain then it has essentially been "created" in your current AppDomain. The source AppDomain could be a separate process on the current computer or another process on a remote computer. As far as I am aware, I don't think that the CLR keeps track of that for you, since you are responsible for moving objects between processes. You would probably need to add a field to your class so that you can set and get that information.
Or consider using a LogicalCallContext object that tracks this information for you while travelling with a call accross appdomains. Here is a good blog by Jeffrey Richter about this.

- 1,153
- 11
- 17
-
I don't mean travelling objects. I want to get the AppDomain in which the object is accessible without moving through the barrier. I have an instance of non-serializable class created in some AppDomain. I want to get that domain. – IS4 Jun 01 '12 at 20:25
-
@IllidanS4: If you're able to access an instance of a non-serializable class from code you've written, wouldn't that instance be sitting inside `AppDomain.CurrentDomain`? – Oliver Apr 10 '14 at 11:34
An object from another app domain is a transparent proxy. It is possible to get the real proxy and access the private field that contains the domain id:
public static int GetObjectAppDomain(object proxy)
{
RealProxy rp = RemotingServices.GetRealProxy(proxy);
int id = (int)rp.GetType().GetField("_domainID", BindingFlags.Instance|BindingFlags.NonPublic).GetValue(rp);
return id;
}
If the list of possible app domains isn't known, here is a way to get the list of all app domains.