空合并运算符和操作顺序?

问题描述

谁能向我解释为什么这个代码

int? a = 54;
decimal b = a ?? 0 / 100m;

b 的值为 54 ?

但是如果我添加一些括号:

int? a = 54;
decimal b = (a ?? 0) / 100m;

它的值为 0.54

我不明白为什么会这样。因为 a 的值为 54,所以我原以为 ?? 运算符什么都不做。

解决方法

From MSDN:

空合并运算符 ??返回其左侧的值 操作数,如果它不为空;否则,它评估右手 操作数并返回其结果。这 ??运营商不评估其 如果左侧操作数的计算结果为非空,则为右侧操作数。

在你的第一种情况下,

int? a = 54;  //Here "a" is not null
decimal b = a ?? 0 / 100m; //As "a" is not null,Value of "a" will be assigned to "b".

在你的第二种情况下,

  // precedence of "(<expression>)" is greater than "null coalescing operator" 
  int b = (a ?? 0) / 100m;
          //+++++++        --This will evaulate first and returns 54
         //          +++  -- This will be calculated as 54 / 100m i.e 0.54
,

?? has lower 优先于 /

1 个案例:

54 ?? (0 / 100) == 54

2 种情况:

(54 ?? 0) / 100 == 0.54

,

只是一个想法:

@rate_limited(max_concurrent=5,duration=5)
async def task(i):
    print(i)


async def main():
    tasks = [asyncio.create_task(task(i)) for i in range(7)]
    await asyncio.gather(*tasks)


if __name__ == "__main__":
    loop = asyncio.get_event_loop()
    loop.run_until_complete(main())

相当于:

decimal b = a ?? 0 / 100m;

所以 decimal b = a ?? (0 / 100m); 不适用于第一种情况

,
decimal b = a ?? 0 / 100m;  

评估为

decimal b;
if (a == null)
{
    b = 0 / 100m;
}
else
{
    b = a;
}
,

这纯粹是运算符优先级的问题。

The documentation lists the order of precedence 用于不同的运算符,您会看到 / 的优先级高于 ??,这意味着它将首先被评估。

所以,

decimal b = a ?? 0 / 100m;

总是被评估为

decimal b = a ?? (0 / 100m);
,
int? a = 54;
decimal b = (a ?? 0) / 100m;

评估为 b = (54) / 100mb = 0.54,如您所见。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...