判断航空公司二字码是否正确的方法:
普通的判断:
private boolean strMatch(String str){ if(str == null || "".equals(str)){ return false; } if(str.length() != 2){ return false; } if(!"ABCDEFGHIJKLMNOPQRSTUVWXYZ".contains(str.substring(0,1))){ return false; } if(!"ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789".contains(str.substring(1,2))){ return false; } return true; }
正则判断:
private boolean regMatch(String str){ String regEx="^[A-Z]{1}[0-9A-Z]{1}$"; Pattern pat=Pattern.compile(regEx); Matcher mat=pat.matcher(str == null ? "" : str); return mat.find(); }
循环调用1000次时,普通方法用时1毫秒,正则用时19毫秒;
循环调用10000次时,普通方法用时3毫秒,正则用时41毫秒;
循环调用100000次时,普通方法用时14毫秒,正则用时172毫秒;
循环调用1000000次时,普通方法用时94毫秒,正则用时1123毫秒; (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|