rspec/rules/S3247/csharp/rule.adoc

48 lines
841 B
Plaintext
Raw Normal View History

2021-04-28 16:49:39 +02:00
Because the ``++is++`` operator performs a cast if the object is not null, using ``++is++`` to check type and then casting the same argument to that type, necessarily performs two casts. The same result can be achieved more efficiently with a single cast using ``++as++``, followed by a null-check.
2021-04-28 16:49:39 +02:00
== Noncompliant Code Example
----
if (x is Fruit) // Noncompliant
{
var f = (Fruit)x; // or x as Fruit
// ...
}
----
2021-04-28 16:49:39 +02:00
== Compliant Solution
----
// C# 6
2021-04-28 16:49:39 +02:00
var f = x as Fruit;
if (f != null)
{
// ...
}
// C# 7
if (x is Fruit fruit)
{
// ...
2021-04-28 16:49:39 +02:00
}
----
ifdef::env-github,rspecator-view[]
'''
== Implementation Specification
(visible only on this page)
include::message.adoc[]
include::highlighting.adoc[]
'''
== Comments And Links
(visible only on this page)
include::comments-and-links.adoc[]
endif::env-github,rspecator-view[]