data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
org.sonar.plugins.csharp.S2955.html Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sonarlint-omnisharp-plugin Show documentation
Show all versions of sonarlint-omnisharp-plugin Show documentation
Code Analyzer based on Omnisharp
Why is this an issue?
In C#, without constraints on a generic type parameter, both reference and value types can be passed. However, comparing
this type parameter to null
can be misleading as value types, like struct
, can never be null.
How to fix it
To avoid unexpected comparisons:
- if you expect a value type, use default() for comparison
- if you expect a reference type, add a constraint to prevent value
types from being passed
Code examples
Noncompliant code example
bool IsDefault<T>(T value)
{
if (value == null) // Noncompliant
{
// ...
}
}
Compliant solution
bool IsDefault<T>(T value)
{
if (EqualityComparer<T>.Default.Equals(value, default(T)))
{
// ...
}
}
or
bool IsDefault<T>(T value) where T : class
{
if (value == null)
{
// ...
}
}
Resources
Documentation
- Microsoft Learn - Constraints on type parameters
- Microsoft Learn - Reference types
- Microsoft Learn - Value types
- Microsoft Learn -
default
operator
© 2015 - 2025 Weber Informatics LLC | Privacy Policy