4

当我将 if-else 更改为返回语句的三元运算符时,我遇到了一种奇怪的行为。

我在这里简化了代码:

class Foo
{
    private bool condition;
    private int intValue = 1;
    private decimal decimalValue = 1M;

    public object TernaryGet
    {
        get
        {
            return condition ? decimalValue : intValue;
        }
    }

    public object IfElseGet
    {
        get
        {
            if (condition)
                return decimalValue;
            return intValue;
        }
    }

    public Foo(bool condition)
    {
        this.condition = condition;
    }
}

class Program
    {
        static void Main(string[] args)
        {
            var fooTrue = new Foo(true);
            var fooFalse = new Foo(false);

            Console.WriteLine("{0}, {1}", fooTrue.TernaryGet.GetType(), fooTrue.IfElseGet.GetType());
            Console.WriteLine("{0}, {1}", fooFalse.TernaryGet.GetType(), fooFalse.IfElseGet.GetType());
        }        
    }

输出是:

System.Decimal, System.Decimal
System.Decimal, System.Int32

我希望第二行在两个 getter 上都输出 Int32,但是对于三元组,我为 int 得到了不正确的 CLR 类型。

别管代码和它试图做什么——我很好奇为什么会这样,所以如果有人能解释一下,我会很感激的。

4

2 回答 2

5

三元(条件)运算符的结果始终是单一类型 - 一个/两个选项被强制转换为通用类型:

var result = condition ? decimalValue : intValue;

类型result必须在编译时静态知道。由于存在从intto类型转换decimaldecimal因此选择类型作为整个? :运算符的类型。

所以你的整个函数可以写成(显示自动转换):

public object TurnaryGet
{
    get
    {
        /*decimal*/ var result = condition ? decimalValue : (decimal)intValue;
        return (object)result;
    }
}
于 2013-04-20T05:43:25.300 回答
2
condition ? decimalValue : intValue;

方法

condition ? decimalValue : (decimal) intValue;

试试这个是否可行:(我对 C# 很陌生,但在 Java 中可以使用)

condition ? (object) decimalValue : (object) intValue;
于 2013-04-20T05:46:58.167 回答