我从未对重载运算符做过任何广泛的工作,尤其是隐式和显式转换。
但是,我有几个经常使用的数字参数,所以我创建了一个结构作为数字类型的包装器来强类型化这些参数。这是一个示例实现:
public struct Parameter
{
private Byte _value;
public Byte Value { get { return _value; } }
public Parameter(Byte value)
{
_value = value;
}
// other methods (GetHashCode, Equals, ToString, etc)
public static implicit operator Byte(Parameter value)
{
return value._value;
}
public static implicit operator Parameter(Byte value)
{
return new Parameter(value);
}
public static explicit operator Int16(Parameter value)
{
return value._value;
}
public static explicit operator Parameter(Int16 value)
{
return new Parameter((Byte)value);
}
}
当我尝试使用我的测试实现来掌握显式和隐式运算符时,我尝试将 a 显式Int64
转换为我的Parameter
类型,令我惊讶的是它没有抛出异常,更令人惊讶的是,它只是截断了数字和继续前进。我尝试排除自定义显式运算符,但它的行为仍然相同。
public void TestCast()
{
try
{
var i = 12000000146;
var p = (Parameter)i;
var d = (Double)p;
Console.WriteLine(i); //Writes 12000000146
Console.WriteLine(p); //Writes 146
Console.WriteLine(d); //Writes 146
}
catch (Exception ex)
{
Console.WriteLine(ex.Message); //Code not reached
}
}
所以我用一个plainByte
代替我的结构重复了我的实验,并且具有相同的确切行为,所以显然这是预期的行为,但我认为导致数据丢失的显式强制转换会引发异常。