Я никогда не проводил обширной работы с операторами перегрузки, особенно с неявными и явными преобразованиями.Явный и неявный оператор с числовыми типами и неожиданные результаты
Однако у меня есть несколько числовых параметров, которые используются часто, поэтому я создаю структуру как оболочку вокруг числового типа, чтобы сильно набирать эти параметры. Вот пример реализация:
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);
}
}
Как я экспериментировал с моей реализацией теста, чтобы получить навык явных и неявных операторов, я попытался явно бросить 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
}
}
Так что я повторил свой эксперимент с простым Byte
вместо моей структуры и имеет такое же точное поведение, так что, очевидно, это ожидаемое поведение, но я думал, что явное приведение, что приводит к терять данные будут бросать исключение.
Нет, явные приведения типов могут потерять информацию. Неявные броски не должны. –
Собираетесь ли вы с помощью 'AnyCPU',' x32' или 'x64'? – ja72
@ ja72 Извините за задержку в ответе, но я компилирую с x86 – psubsee2003