ReleaseComObject and IsComObject
We had a COM Object that needed to have ReleaseComObject called on it. This worked fine, and happily for a while. Then, someone created a .NET object with the exact same signature so that it might easily replace the use of the COM object. However, this new assemebly is NOT a COM Object, so it's extraordinarily bad to call ReleaseComObject on it (in that it totally doesn't work.)
So, here's a good best practice if you're doing some crazy crap like this:
if(Marshal.IsComObject(foo)) Marshal.ReleaseComObject(foo);
About Scott
Scott Hanselman is a former professor, former Chief Architect in finance, now speaker, consultant, father, diabetic, and Microsoft employee. He is a failed stand-up comic, a cornrower, and a book author.
data:image/s3,"s3://crabby-images/df293/df2930ba17822db6d18c17037402274be1f59b27" alt="facebook"
data:image/s3,"s3://crabby-images/bd449/bd4494b4db633a4a36c95a93eb47c11698a1fe07" alt="bluesky"
data:image/s3,"s3://crabby-images/905e8/905e839e39ccf148e04d8b5106dc6eeb6112defd" alt="subscribe"
About Newsletter
Do we really want to know via an exception that the operation is meaningless?
--
Thomas
Comments are closed.
That all works unless your client code calls ReleaseComObject without checking IsComObject first. Since it isn't a COM object anymore you will get an InvalidCastException. Like Scott said, it's a good practice as it allows you to convert your legacy COM objects to managed code in the future with no client side code change.