Close, but only 1/2 a cigar
Date is not a wrapper. It is an alias to System.DateTime. The compiler sees
this, and writes System.DateTime in the background. Just like string
(lowercase) is a C# alias for System.String.
However, you are correct in that System.DateTime is a value type (in this
case, structure), and not a reference type. Where the line becomes fuzzy
about "right/wrong/bug/feature" is that while you cannot directly assign
null to a value type, you can box value types and treat them like reference
types. Adrian's example in C#, using more explicit boxing, would produce:
return (DateTime)((Object)null);
which C# does in fact let you compile, although this produces a runtime null
exception.
And though you cannot explicitly and directly assign null to a value type in
C#, it is perfectly valid with reguards to the C# compiler to assign a
reference type value which *MIGHT* be null, though again, you would get a
runtime null exception.
In VB's case, as you state, VB "helpfully" invokes
MS.VB.CompilerServices.DateType.FromObject(null) to initialize the date
variable, which in thise case produces DateTime.MinValue, partly because
it's a VB language feature that all local variables of value types are
initialized to a default value. They are never in an "unassigned" state. In
C#, you are forced to initialize them explicitly before you use them.
-Rob Teixeira [MVP]
Philip Rieck said:
I'd almost consider this a VB.NET bug, but that's just me. C# wouldn't have
let you compile this at all.
Date is actually a VB.NET language wrapper around System.DateTime.
System.DateTime is not a class, it's a structure - which is a value type.
What that means to you is you can't assign nothing to a value type, so you
cant assign Nothing to a Date.
VB.NET "helpfully" changes your
[myDate = nothing] line (which is basically what is hapenning) into
[myDate = Date.MinValue] (which is the the same value VB.NET will
initialize Date types into by default if you don't initalize them
explicitly.
That's why you're seeing confusing behavior.
Adrian Parker said:
'function to convert null to nothing
Function CheckDate(ByVal DRow As DataRow, ByVal strCol As String) As Date
If DRow.Item(strCol) Is System.DBNull.Value Then
Return Nothing
Else
Return DRow.Item(strCol)
End If
End Function
Dim DRow as DataRow
Dim myDate as Date
' do some sql to pupulate DRow with data (column EndDate is null)
' then..
myDate = CheckDate(myDataRow,"EndDate")
if I look at myDate now, it contains 12:00am instead of Nothing.. why
?
The CheckDate function gets to the Return Nothing line,
but that is not what gets assigned to myDate