您的位置:首页 > 运维架构 > Linux

linux 源代码安装web服务器

2013-12-30 16:42 197 查看
今天看原来项目的代码,又让我发现了一处很urgly的代码,原来的程序员是这么判断传进去的字符串是否是整型或者浮点型数格式的数,他是这么做的:直接用parseInt或者parseDouble看调用这两个函数是否发生异常,如果发生异常,说明不符合,没有异常,则符合。

不能说这样做不对,但code smell太重,而且这种做法显得很诡异,靠抛异常来检查。。。。
(如果异常是由其它原因引起的呢??)这种编程风格非常不好,不过担心之前程序程序员已经用了多次这种手法,我只好自己另外写了两个函数,并且在他原来的函数里添加一些建议使用我现在写的函数的注释。

比较好的做法应该是用正则表达式判断是否符合整型或者是浮点型数格式。

看代码就知道了:
/**
* 判断number参数是否是整型数表示方式
* @param number
* @return
*/
public static boolean isIntegerNumber(String number){
number=number.trim();
String intNumRegex="\\-{0,1}\\d+";//整数的正则表达式
if(number.matches(intNumRegex))
return true;
else
return false;
}

/**
* 判断number参数是否是浮点数表示方式
* @param number
* @return
*/
public static boolean isFloatPointNumber(String number){
number=number.trim();
String pointPrefix="(\\-|\\+){0,1}\\d*\\.\\d+";//浮点数的正则表达式-小数点在中间与前面
String pointSuffix="(\\-|\\+){0,1}\\d+\\.";//浮点数的正则表达式-小数点在后面
if(number.matches(pointPrefix)||number.matches(pointSuffix))
return true;
else
return false;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: