What rules govern cross-version compatibility for .NET applications and the C# language?
        Posted  
        
            by John Feminella
        on Stack Overflow
        
        See other posts from Stack Overflow
        
            or by John Feminella
        
        
        
        Published on 2010-02-25T13:01:17Z
        Indexed on 
            2010/05/08
            23:28 UTC
        
        
        Read the original article
        Hit count: 244
        
For some reason I've always had trouble remembering the backwards/forwards compatibility guarantees made by the framework, so I'd like to put that to bed forever.
Suppose I have two assemblies, A and B. A is older and references .NET 2.0 assemblies; B references .NET 3.5 assemblies. I have the source for A and B, Ax and Bx, respectively; they are written in C# at the 2.0 and 3.0 language levels. (That is, Ax uses no features that were introduced later than C# 2.0; likewise Bx uses no features that were introduced later than 3.0.)
I have two environments, C and D. C has the .NET 2.0 framework installed; D has the .NET 3.5 framework installed.
Now, which of the following can/can't I do?
Running:
- run AonC? runAonD?
- run BonC? runConD?
Compiling:
- compile AxonC? compileAxonD?
- compile BxonC? compileBxonD?
Rewriting:
- rewrite Axto use features from the C# 3 language level, and compile it onD, while having it still work onC?
- rewrite Bxto use features from the C# 4 language level on another environmentEthat has .NET 4, while having it still work onD?'
Referencing from another assembly:
- reference BfromAand have a client app onCuse it?
- reference BfromAand have a client app onDuse it?
- reference AfromBand have a client app onCuse it?
- reference AfromBand have a client app onDuse it?
More importantly, what rules govern the truth or falsity of these hypothetical scenarios?
© Stack Overflow or respective owner