3.26. Writing Code that Is Compatible with the Widest Range of Managed Languages
Problem
You need to make sure your C# code will interoperate with all other managed languages that are CLS-compliant consumers, such as VB.NET.
Solution
Mark the assembly with the CLSCompliantAttribute:
[assembly: CLSCompliantAttribute(true)]
Discussion
By default, your C# assemblies created with VS.NET are not marked
with the CLSCompliantAttribute. This does not mean
that the assembly will not work in the managed environment. It means
that this assembly may use elements that are not recognized by other
Common Language Specification (CLS)-compliant languages. For example,
unsigned numeric types are not recognized by all managed languages,
but they can be used in the C# language. The problem occurs when C#
returns an unsigned data type, such as uint,
either through a return value or a parameter to a calling component
in another language that does not recognize unsigned data
types—VB.NET is one example.
Tip
CLS compliance is enforced only on types/members marked public or protected. This makes sense because components written in other languages will only be able to use the public or protected types/members of components written in C#.
Marking your assembly as CLS-compliant means that any CLS-compliant language will be able to seamlessly interoperate with your code; that is, it enables CLS-compliance checking. It should also be noted that if you have types and/or members within those types that are not CLS-compliant, ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access