I have an \'optional\' parameter on a method that is a KeyValuePair. I wanted an overload that passes null to the core method for this parameter, but in the core method, wh
KeyValuePair<K,V>
is a struct, not a class. It's like doing:
int i = 10;
if (i != null) ...
(Although that is actually legal, with a warning, due to odd nullable conversion rules. The important bit is that the if
condition will never be true.)
To make it "optional", you can use the nullable form:
static void Foo(KeyValuePair<object,string>? pair)
{
if (pair != null)
{
}
// Other code
}
Note the ? in KeyValuePair<object,string>?
I'm answering this despite its age because it is the 1st Google result for "test keyvaluepair to null"
The answer specified is correct, but it doesn't completely answer the problem, at least the one I was having, where I need to test the existence of the KeyValuePair
and move on to another check of the Dictionary
if it doesn't exist the way I'm expecting.
Using the method above didn't work for me because the compiler chokes on getting KeyValuePair.Value
of KeyValuePair<>?
, so it is better to utilize default(KeyValuePair<>)
as seen in this question + answers. The default for KeyValuePair
KeyValuePair<K,V> is a struct and hence can't be null under any circumstances. Only a reference type can be null.
If you're trying to catch an incorrect value you'll have to validate the Key and Value members individually.
Because KeyValuePair is structure (a value type), you can only compare nulls on reference types.
I'm guessing you haven't written that extra overload yet. It will fail when you attempt to pass null as the value of a KeyValuePair.
You can actually use KeyValuePair.IsNull() to determine if the KeyValuePair has been set.