目录
- 目录
- 前言
- 关键点
- Java代码实现
前言
早上看了一下CSDN博客排名,本周最高排名的文章是:Java实现比较版本号。个人认为这篇文章写的不错,因为Android客户端系统中经常用到版本号比较功能,特别是在应用自升级的情况下。
原博主之所以写这篇文章,是因为考虑到大部分Java程序员可能会采用compareTo这种不靠谱的API调用或者不规则的版本号名称。
而我写这篇文章,是由于对ACM题目的推崇和补充一下原博主代码中考虑不够周全的情况。
关键点
这里,分两个问题来说明一下客户端版本号比较的关键点。
为什么不能使用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题目?
之所以这里推荐一下大家做ACM,是因为我最早思考这类问题是通过LeetCode上一道难度为easy的字符串比较题目,题目链接:Compare Version Number。而原博主的代码是无法AC这道题目的。
Java代码实现
扯了一些,最后还是要show一下代码的,以下是我的客户端版本号比较代码,欢迎吐槽。
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;
}
}
时间: 2024-10-01 20:45:26