为什么不有条件的经营者正确地允许使用"零"用于分配给可空类型?有条件、经营者、正确地、类型

2023-09-02 10:33:26 作者:掌控天下的神

可能显示的文件:   Nullable类型和三元运算符。为什么赢得&rsquo的;?吨这项工作   Conditional可空&LT运营商分配;价值>类型?

这不能编译,指出有条件的前pression类型无法确定,因为没有'System.DateTime的'和''之间的隐式转换

  task.ActualEndDate = TextBoxActualEndDate.Text!=? DateTime.Parse(TextBoxActualEndDate.Text):空;
 

这只是正常工作

 如果(TextBoxActualEndDate.Text!=)
    task.ActualEndDate = DateTime.Parse(TextBoxActualEndDate.Text);
其他
    task.ActualEndDate = NULL;
 
警惕 收到这类短信千万不要点开

解决方案

这不起作用,因为编译器不会一下子插入两侧的隐式转换,而需要一个隐式转换成为可空类型。

相反,你可以写

  task.ActualEndDate = TextBoxActualEndDate.Text!=?
    DateTime.Parse(TextBoxActualEndDate.Text):新的datetime();?
 

这仅需要一个隐式转换(的DateTime 日期时间?)。

另外,你可以施展任何左侧:

  task.ActualEndDate = TextBoxActualEndDate.Text!=?
    (日期时间?)DateTime.Parse(TextBoxActualEndDate.Text):空;
 

这也只需要一个隐式转换。

Possible Duplicates: Nullable types and the ternary operator. Why won’t this work? Conditional operator assignment with nullable<value> types?

This will not compile, stating "Type of conditional expression cannot be determined because there is no implicit conversion between 'System.DateTime' and ''"

task.ActualEndDate = TextBoxActualEndDate.Text != "" ? DateTime.Parse(TextBoxActualEndDate.Text) : null;

This works just fine

 if (TextBoxActualEndDate.Text != "")
    task.ActualEndDate = DateTime.Parse(TextBoxActualEndDate.Text);
else
    task.ActualEndDate = null;

解决方案

This doesn't work because the compiler will not insert an implicit conversion on both sides at once, and null requires an implicit conversion to become a nullable type.

Instead, you can write

task.ActualEndDate = TextBoxActualEndDate.Text != "" ? 
    DateTime.Parse(TextBoxActualEndDate.Text) : new DateTime?();

This only requires one implicit conversion (DateTime to DateTime?).

Alternatively, you can cast either left side:

task.ActualEndDate = TextBoxActualEndDate.Text != "" ? 
    (DateTime?)DateTime.Parse(TextBoxActualEndDate.Text) : null;

This also requires only one implicit conversion.