nodejs实现版本号比较

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nodejs实现版本号比较相关的知识,希望对你有一定的参考价值。

参考技术A 一般程序版本号形式x.x.x.x的字符串,例如:1.0、1.0.0、1.0.0.0。如果直接采用字符串比较大小,会出现低版本大于高版本的结果,例如:1.10.1和1.9.2比较,就会出现"1.9.2" > "1.10.1"。所以需要对于每一位分开,采用补位的方式逐个比较。

Java实现比较版本号

涉及到客户端的系统中经常需要用到比较版本号的功能,但是比较版本号又不能完全按照字符串比较的方式去用compareTo之类的方法;

这就需要我们总结版本号的通用规则,设计一个比较算法并封装成通用方法来使用:

通常版本号如:1.3.20.8,6.82.20160101,8.5a/8.5c等;

通用规则就是,先将版本字符串按照点号分割,然后主版本与主版本比较、此版本与此版本比较,如此按序一级一级往后比较,直到有分出大小;

值得注意的是,很多比较版本号的方法都先将字符串转换成int或者double类型,这样做未必通用,因为可能含有字母,如8.5c这样的版本号;

通用的方式依然是将分割后的字符串当做字符串来比较,不过,比较字符串之前,先比较位数;

比较版本号的方法示例:

  1. /** 
  2.  * 比较版本号的大小,前者大则返回一个正数,后者大返回一个负数,相等则返回0 
  3.  * @param version1 
  4.  * @param version2 
  5.  * @return 
  6.  */  
  7. public static int compareVersion(String version1, String version2) throws Exception {  
  8.     if (version1 == null || version2 == null) {  
  9.         throw new Exception("compareVersion error:illegal params.");  
  10.     }  
  11.     String[] versionArray1 = version1.split("\\.");//注意此处为正则匹配,不能用".";  
  12.     String[] versionArray2 = version2.split("\\.");  
  13.     int idx = 0;  
  14.     int minLength = Math.min(versionArray1.length, versionArray2.length);//取最小长度值  
  15.     int diff = 0;  
  16.     while (idx < minLength  
  17.             && (diff = versionArray1[idx].length() - versionArray2[idx].length()) == 0//先比较长度  
  18.             && (diff = versionArray1[idx].compareTo(versionArray2[idx])) == 0) {//再比较字符  
  19.         ++idx;  
  20.     }  
  21.     //如果已经分出大小,则直接返回,如果未分出大小,则再比较位数,有子版本的为大;  
  22.     diff = (diff != 0) ? diff : versionArray1.length - versionArray2.length;  
  23.     return diff;  
  24. }  

注意:其中 split 方法入参为正则匹配表达式,不能用"."("."在正则表达式里匹配任何值),需要用"\\.",才算是按点号分割;

这样,先分割成子串数组,再挨个比较子版本号,比较子版本号时,先比较位数,位数大的就大,位数一样时再按字符串比较方式比较;

如果全部比较完(其中一个版本号比较完)之后,再看一下哪个版本号有更更多的子版本号,也就是分割后的数组长度,有子版本号的为大;

这样就比较完善地考虑了各种情况,并比较出版本号大小;包括有字母后缀的也可以使用;

如 "9.9", "10.8.8.6" ,如果直接按字符串比较,则会前者大,后者小,而明显是错误的;分割后比较第一个主版本9与10,从位数上,就已经得出结果后者大;

再如 "9.9b", "9.8a" 等也适用,如果用转换成int或者double的方法就不适用;

欢迎指正!

 

http://blog.csdn.net/sowhat_ah/article/details/43955337

以上是关于nodejs实现版本号比较的主要内容,如果未能解决你的问题,请参考以下文章

Java实现比较版本号

JS 实现版本号比较功能

LeetCode第165题—比较版本号—Python实现

LeetCode第165题—比较版本号—Python实现

LeetCode第165题—比较版本号—Python实现

LeetCode第165题—比较版本号—Python实现