微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 而不是错误,为什么两个操作数都不会被提升为float或double?

1)如果一个操作数是ulong类型,而另一个操作数是sbyte / short / int / long类型,则发生编译时错误.我没有看到这个逻辑.因此,为什么两个操作数被提升为double或float类型是不是一个坏主意?
long L = 100;
        ulong UL = 1000;
        double d = L + UL; // error saying + operator can't be applied
                              to operands of type ulong and long

b)编译器隐式地将int literal转换为字节类型并将结果值赋给b:

byte b = 1;

但是如果我们尝试为long类型(或类型int,byte等)分配ulong类型的文字,那么编译器会报告错误

long L = 1000UL;

我认为编译器能够弄清楚常量表达式的结果是否适合long类型的变量?!

谢谢

解决方法

要回答标记为(1)的问题 – 添加有符号和无符号长度可能是一个错误.如果开发人员的意图是在这种情况下溢出到不精确的算术,那么他们应该通过将两个参数都转换为double来明确地做.隐含地这样做是为了更多地隐藏错误而不是做正确的事情.

回答标记为(b)的问题 – 当然编译器可以解决这个问题.显然它可以因为它对整数文字这样做.但同样,这几乎肯定是一个错误.如果你的意图是签名长,那你为什么把它标记为未签名?这看起来像是一个错误. C#经过精心设计,因此它会寻找像这样的奇怪模式并引起你的注意,而不是猜测你是想说出这个奇怪的东西并且在前方炽热,好像一切正​​常.编译器试图鼓励你编写合理的代码;敏感代码不会混合有符号和无符号类型.

原文地址:https://www.jb51.cc/csharp/98694.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐