我一直認爲DbNull.value是一個單身人士。這樣的話你可以做這樣的事情:當我使用XmlSerialiser進行反序列化時,爲什麼不是我的DbNull單例?
VB.NET:
If someObject Is DbNull.Value Then
...
End if
C#:
If (someObject == DbNull.Value)
{
...
}
但最近,我連載使用XmlSerialiser一個實例,則爲DBNull,突然它不是再單身一人。類型比較操作(如C#的(obj是DBNull))工作確定。
代碼如下:
[Serializable, System.Xml.Serialization.XmlInclude(typeof(DBNull))]
public class SerialiseMe
{
public SerialiseMe() { }
public SerialiseMe(object value)
{
this.ICanBeDbNull = value;
}
public Object ICanBeDbNull { get; set; }
}
public void Foo()
{
var serialiseDbNull = new SerialiseMe(DBNull.Value);
var serialiser = new System.Xml.Serialization.XmlSerializer(typeof(SerialiseMe));
var ms = new System.IO.MemoryStream();
serialiser.Serialize(ms, serialiseDbNull);
ms.Seek(0, System.IO.SeekOrigin.Begin);
var deSerialisedDbNull = (SerialiseMe)serialiser.Deserialize(ms);
// Is false, WTF!
var equalsDbNullDeserialised = deSerialisedDbNull.ICanBeDbNull == DBNull.Value;
// Is false, WTF!
var refEqualsDbNullDeserialised = object.ReferenceEquals(deSerialisedDbNull.ICanBeDbNull, DBNull.Value);
// Is true.
var convertIsDbNullDeserialised = Convert.IsDBNull(deSerialisedDbNull.ICanBeDbNull);
// Is true.
var isIsDbNullDeserialised = deSerialisedDbNull.ICanBeDbNull is DBNull;
}
爲什麼會出現這種情況?它是如何發生的?它可能會發生與其他任何靜態字段?
PS:我知道VB代碼示例正在做參考比較,而c#正在調用Object.Equals。兩者與DBNull具有相同的行爲。我通常使用VB。
我一直在搞相當幾個小時的東西......我甚至沒有想過要試試DBNull。 – Feign 2015-01-13 16:39:29