zoukankan      html  css  js  c++  java
  • 编写高质量代码改善C#程序的157个建议——建议113:声明变量前考虑最大值

    建议113:声明变量前考虑最大值

    假设正在开发一个工资系统,其中一个模块负责处理加薪。代码如下:

            static void Main(string[] args)
            {
                ushort salary = 65534;
                salary = (ushort)(salary + 1);
                Console.WriteLine(string.Format("第一次加薪,工资总数:{0}", salary));
                salary = (ushort)(salary + 1);
                Console.WriteLine(string.Format("第二次加薪,工资总数:{0}", salary));
            }

    输出的结果是:

    第一次加薪,工资总数:65535
    第二次加薪,工资总数:0

    工资被清零了。

    如果让一个刚入行的程序员来写工资系统,他可能会给我们设计一个ushort字段来存储月薪。65535元?够多了,谁的月薪会超过这个数?当然,这里举的是一个极端的例子。在这个例子中我们存在很多机会去修正这个Bug。但是,即便是最有经验的程序员,也会犯这种错误。在一个千万级的数据表中统计历史数据,你认为某个字段的求和极值会是多少?

    上面的错误貌似愚蠢低级,可是一不留神,我们就可能掉入这样的陷阱。所以应该始终在声明变量时考虑最大值。

    在C#中,如果要避免犯类似的错误,有一个补救措施,那就是为运算加上checked关键字。在运行溢出的时候它会抛出一个异常:

            static void Main(string[] args)
            {
                ushort salary = 65534;
                checked
                {
                    salary = (ushort)(salary + 1);
                    Console.WriteLine(string.Format("第一次加薪,工资总数:{0}", salary));
                    salary = (ushort)(salary + 1);
                    Console.WriteLine(string.Format("第二次加薪,工资总数:{0}", salary));
                }
            }

    经过修正的代码在运行到第二次加薪的时候,会抛出System.OverflowException:算术运算导致溢出。

    转自:《编写高质量代码改善C#程序的157个建议》陆敏技

  • 相关阅读:
    《程序员修炼之道》阅读笔记2
    《程序员修炼之道》阅读笔记1
    Ubuntu16桥接模式上网并设置静态ip
    读《架构漫谈》有感
    质量属性6个常见属性的场景分析
    sql注水
    python版本切换
    使用vue-cli构建 webpack打包工具时,生产环境下,每次build时,删除dist目录,并重新生成,以防dist目录文件越来越多。
    Java栈与堆
    从一个字符串s的第i个字符(不包括此字符)开始删除n个字符
  • 原文地址:https://www.cnblogs.com/jesselzj/p/4749642.html
Copyright © 2011-2022 走看看