打字猴:1.70043956e+09
1700439560
1700439561 我曾遇到过一个类似的事故,那是开发一个通过会员等级决定相关费率的系统,由于会员等级有100多个,所以测试时就采用了抽样测试的方法,测试时一切顺利,直到系统上线后,财务报表系统发现一个小概率的会员费率竟然出奇的低,于是就跟踪分析,发现是少了一个break,此事不仅造成甲方经济上的损失,而且在外部也产生了不良的影响,最后该代码的作者被辞退了,测试人员、质量负责人、项目经理都做了相应的处罚。希望读者能引以为戒,记住在case语句后面随手写上break,养成良好的习惯。
1700439562
1700439563 对于此类问题,还有一个最简单的解决办法:修改IDE的警告级别,例如在Eclipse中,可以依次点击Performaces→Java→Compiler→Errors/Warnings→Potential Programming problems,然后修改‘switch’case fall-through为Errors级别,如果你胆敢不在case语句中加入break,那Eclipse直接就报个红叉给你看,这样就可以完全避免该问题的发生了。
1700439564
1700439565
1700439566
1700439567
1700439568 编写高质量代码:改善Java程序的151个建议 [:1700438083]
1700439569 编写高质量代码:改善Java程序的151个建议 建议16:易变业务使用脚本语言编写
1700439570
1700439571 Java世界一直在遭受着异种语言的入侵,比如PHP、Ruby、Groovy、JavaScript等,这些“入侵者”都有一个共同特征:全是同一类语言—脚本语言,它们都是在运行期解释执行的。为什么Java这种强编译型语言会需要这些脚本语言呢?那是因为脚本语言的三大特征,如下所示:
1700439572
1700439573 灵活。脚本语言一般都是动态类型,可以不用声明变量类型而直接使用,也可以在运行期改变类型。
1700439574
1700439575 便捷。脚本语言是一种解释型语言,不需要编译成二进制代码,也不需要像Java一样生成字节码。它的执行是依靠解释器解释的,因此在运行期变更代码非常容易,而且不用停止应用。
1700439576
1700439577 简单。只能说部分脚本语言简单,比如Groovy, Java程序员若转到Groovy程序语言上,只需要两个小时,看完语法说明,看完Demo即可使用了,没有太多的技术门槛。
1700439578
1700439579 脚本语言的这些特性是Java所缺少的,引入脚本语言可以使Java更强大,于是Java 6开始正式支持脚本语言。但是因为脚本语言比较多,Java的开发者也很难确定该支持哪种语言,于是JCP(Java Community Process)很聪明地提出了JSR223规范,只要符合该规范的语言都可以在Java平台上运行(它对JavaScript是默认支持的),诸位读者有兴趣的话可以自己写个脚本语言,然后再实现ScriptEngine,即可在Java平台上运行。
1700439580
1700439581 我们来分析一个案例,展现一下脚本语言是如何实现“拥抱变化”的。咱们编写一套模型计算公式,预测下一个工作日的股票走势(如果真有,那巴菲特就羞愧死了),即把国家政策、汇率、利率、地域系数等参数输入到公式中,然后计算出明天这支股票是涨还是跌,该公式是依靠历史数据推断而来的,会根据市场环境逐渐优化调整,也就是逐渐趋向“真理”的过程,在此过程中,公式经常需要修改(这里的修改不仅仅是参数修改,还涉及公式的算法修改),如果把这个公式写到一个类中(或者几个类中),就需要经常发布重启等操作(比如业务中断,需要冒烟测试(Smoke Testing)等),使用脚本语言则可以很好地简化这一过程,我们写一个简单公式来模拟一下,代码如下:
1700439582
1700439583 function formula(var1,var2){
1700439584
1700439585 return var1+var2*factor;
1700439586
1700439587 }
1700439588
1700439589 这就是一个简单的脚本语言函数,可能你会很疑惑:factor(因子)这个变量是从哪儿来的?它是从上下文来的,类似于一个运行的环境变量。该JavaScript保存在C:/model.js中。下一步Java需要调用JavaScript公式,代码如下:
1700439590
1700439591 public static void main(String[]args)throws Exception{
1700439592
1700439593 //获得一个JavaScript的执行引擎
1700439594
1700439595 ScriptEngine engine=new ScriptEngineManager().getEngineByName(“javascript”);
1700439596
1700439597 //建立上下文变量
1700439598
1700439599 Bindings bind=engine.createBindings();
1700439600
1700439601 bind.put(“factor”,1);
1700439602
1700439603 //绑定上下文,作用域是当前引擎范围
1700439604
1700439605 engine.setBindings(bind, ScriptContext.ENGINE_SCOPE);
1700439606
1700439607 Scanner input=new Scanner(System.in);
1700439608
1700439609 while(input.hasNextInt()){
[ 上一页 ]  [ :1.70043956e+09 ]  [ 下一页 ]