views:

173

answers:

3

Just for my clarification :

Can i throw both CLS-Complaint and non-CLS complaint exceptions in .NET Framework ?.I am using C# 3.0.

When i catch exception

catch(Exception ex)
{

}
  • Will it catch only CLS-Complaint exceptions?.
  • What is the use of RuntimeWrappedException class (can i have a simple example?).
+5  A: 
  1. Yes, you can throw non-CLS compliant exceptions in the .NET Framework, as long as you use a language that allows it, e.g. C++.
  2. No, you cannot throw non-CLS compliant exceptions in C#.
  3. No, it will catch all exceptions, since any non-CLS compliant exception will be wrapped in a RuntimeWrappedException, which derives from Exception.
  4. You do not throw a RuntimeWrappedException, the CLR does. MSDN has a detailed description, which I quote here:

    Some languages, such as C++, allow you to throw exceptions of any managed type. Other languages, such as Microsoft C# and Visual Basic, require that every thrown exception be derived from the Exception class. To maintain compatibility between languages, the common language runtime (CLR) wraps objects that do not derive from Exception in a RuntimeWrappedException object.

If you want to treat CLS and non-CLS exceptions differently, just catch them in the right order:

try {
    // some code
catch(RuntimeWrappedException ex) {
    // non-CLS exceptions
catch(Exception ex) {
    // CLS exceptions
}
Christian Hayter
A: 

Although the C# compiler allows developers to throw Exception-derived objects only, prior to C# version 2.0, the C# compiler did allow developers to catch non-CLS-compliant exceptions by using code like this:

private void SomeMethod() { 
try { 
// Inside the try block is where you put code requiring 
// graceful recovery or common cleanup operations. 
}
catch (Exception e) { 
// Before C# 2.0, this block catches CLS-compliant exceptions only 
// In C# 2.0, this block catches CLS- & non-CLS- compliant exceptions 
throw; // Re-throws whatever got caught 
}
catch { 
// In all versions of C#, this block catches 
// CLS- & non-CLS- compliant exceptions 
throw; // Re-throws whatever got caught 
}
}
Dzmitry Huba
A: 

The CLS allows it but not all languages do. It can be done with C++/CLI but it can’t with C#, VB.NET.

Starting with .Net Framework 2.0, all non-CLS exceptions are wrapped inside a RuntimeWrappedException.

Since RuntimeWrappedException derives from Exception, a catch (Exception) will catch non-CLS exceptions.

From a RuntimeWrappedException you can access the original exception through RuntimeWrappedException.WrappedException property.

Alfred Myers