I was doing some type conversion routines last night for a system I am working on. One of the conversions involves turning string values into their DateTime equivalents.
While doing this, I noticed that the Convert.ToDateTime() method had an overload which accepted a boolean parameter.
First question? Under what circumstances could this ever be useful?
I went a little further and tried to execute the method in QuickWatch. Either way ( true or false ), the routine returns an InvalidCastException.
Second question? Why is this method even here?
EDIT
Thanks for the answers, guys. I can see how it makes sense from a contractual point of view, but it does seem odd that the core framework includes methods that:-
It's a bit like someone making a car loaded with controls that actively stop your vehicle from working when used.
It makes sense because ToDateTime
is part of the IConvertible
interface implemented by bool
. If you look in reflector you will see that it throws an InvalidCastException
.
Update (from Convert
):
public static DateTime ToDateTime(bool value)
{
return ((IConvertible) value).ToDateTime(null);
}
I think it's there for completeness and that you get an explicit InvalidCastException when calling Convert.ToDateTime with an object that is a bool.
If you look at all the members of Convert, you can see that overloads have been included to accept all the basic types for conversion to each of the other basic types, with InvalidCastExceptions being thrown when there is no sensible conversion.
I guess they thought this would be more meaningful than just not having the overloads there at all.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With