Application compatibility in .NET Framework
Compatibility is an important goal of each .NET Framework release. Compatibility ensures that each version is additive, so previous versions will continue to work. On the other hand, changes to previous functionality (for example, to improve performance, address security issues, or fix bugs) can cause compatibility problems in existing code or existing applications that run under a later version.
Each app targets a specific version of .NET Framework by:
- Defining a target framework in Visual Studio.
- Specifying the target framework in a project file.
- Applying a TargetFrameworkAttribute to the source code.
When migrating from one version of .NET Framework to another, there are two types of changes to consider:
Runtime changes
Runtime issues are those that arise when a new runtime is placed on a machine and an app's behavior changes. When running on a newer version than what was targeted, .NET Framework uses quirked behavior to mimic the older targeted version. The app runs on the newer version but acts as if it's running on the older version. Many of the compatibility issues between versions of .NET Framework are mitigated through this quirking model. For example, if a binary was compiled for .NET Framework 4.0 but runs on a machine with .NET Framework 4.5 or later, it runs in .NET Framework 4.0 compatibility mode. This means that many of the changes in the later version don't affect the binary.
The version of .NET Framework that an application targets is determined by the target version of the entry assembly for the application domain that the code runs in. All additional assemblies loaded in that application domain target that version. For example, in the case of an executable, the version that the executable targets is the compatibility mode all assemblies in that application domain run under.
Retargeting changes
Retargeting changes are those that arise when an assembly is recompiled to target a newer version. Targeting a newer version means the assembly opts into the new features as well as potential compatibility issues for old features.
Impact classification
In the articles that describe runtime and retargeting changes, for example, Retargeting changes for migration to .NET Framework 4.8.x, individual items are classified by their expected impact as follows:
Major
A significant change that affects a large number of apps or that requires substantial modification of code.
Minor
A change that affects a small number of apps or that requires minor modification of code.
Edge case
A change that affects apps under very specific scenarios that are not common.
Transparent
A change that has no noticeable effect on the app's developer or user. The app should not require modification because of this change.