早上看了1下CSDN博客排名,本周最高排名的文章是:Java实现比较版本号。个人认为这篇文章写的不错,由于Android客户端系统中常常用到版本号比较功能,特别是在利用自升级的情况下。
原博主之所以写这篇文章,是由于斟酌到大部份Java程序员可能会采取compareTo这类不靠谱的API调用或不规则的版本号名称。
而我写这篇文章,是由于对ACM题目的推重和补充1下原博主代码中斟酌不够周全的情况。
这里,分两个问题来讲明1下客户端版本号比较的关键点。
为何不能使用String.compareTo方法来比较客户端版本号?
举个栗子,之前客户端版本号为:9.9.9,而服务器端最新的客户端版本号为:10.0.1,虽然10.0.1明显高于9.9.9,但是依照compareTo方法,这个9.9.9是大于10.0.1的,致使客户端版本号比较毛病。原博主代码中欠缺哪些斟酌?
原博主斟酌了8.5c这类不太可能定义的版本号,却没有斟酌版本号中前导0的情况。例如,依照原博主的代码,版本号1.0是大于版本号1的。为何推重ACM题目?
之所以这里推荐1下大家做ACM,是由于我最早思考这类问题是通过LeetCode上1道难度为easy的字符串比较题目,题目链接:Compare Version Number。而原博主的代码是没法AC这道题目的。
扯了1些,最后还是要show1下代码的,以下是我的客户端版本号比较代码,欢迎吐槽。
public static int compareVersion(String version1, String version2) {
if (version1.equals(version2)) {
return 0;
}
String[] version1Array = version1.split(".");
String[] version2Array = version2.split(".");
int index = 0;
int minLen = Math.min(version1Array.length, version2Array.length);
int diff = 0;
while (index < minLen && (diff = Integer.parseInt(version1Array[index]) - Integer.parseInt(version2Array[index])) == 0) {
index ++;
}
if (diff == 0) {
for (int i = index; i < version1Array.length; i ++) {
if (Integer.parseInt(version1Array[i]) > 0) {
return 1;
}
}
for (int i = index; i < version2Array.length; i ++) {
if (Integer.parseInt(version2Array[i]) > 0) {
return -1;
}
}
return 0;
} else {
return diff > 0 ? 1 : -1;
}
}