版本号对比 比较大小 (版本比较)

可以根据服务器各种版本比较
支持不同位数的比较 2.0.0.0.0.1 2.0 对比
“3.0”, “3”
“3.0.0.1”, “3.0”
“3.0.0”, “3.0”

 /**
     * 如果版本1 大于 版本2 返回true 否则返回fasle 支持 2.2 2.2.1 比较
     * 支持不同位数的比较  2.0.0.0.0.1  2.0 对比
     *
     * @param v1 版本服务器版本 " 1.1.2 "
     * @param v2 版本 当前版本 " 1.2.1 "
     * @return ture :需要更新 false : 不需要更新
     */
        public static boolean compareVersions(String v1, String v2) {
        //判断是否为空数据
        if (TextUtils.equals(v1, "") || TextUtils.equals(v2, "")) {
            return false;
        } 
        String[] str1 = v1.split("\\.");
        String[] str2 = v2.split("\\.");

        if (str1.length == str2.length) {
            for (int i = 0; i < str1.length; i++) {
                if (Integer.parseInt(str1[i]) > Integer.parseInt(str2[i])) {
                    return true;
                } else if (Integer.parseInt(str1[i]) < Integer.parseInt(str2[i])) {
                    return false;
                } else if (Integer.parseInt(str1[i]) == Integer.parseInt(str2[i])) {

                }
            }
        } else {
            if (str1.length > str2.length) {
                for (int i = 0; i < str2.length; i++) {
                    if (Integer.parseInt(str1[i]) > Integer.parseInt(str2[i])) {
                        return true;
                    } else if (Integer.parseInt(str1[i]) < Integer.parseInt(str2[i])) {
                        return false;

                    } else if (Integer.parseInt(str1[i]) == Integer.parseInt(str2[i])) {
                        if (str2.length == 1) {
                            continue;
                        }
                        if (i == str2.length - 1) {

                            for (int j = i; j < str1.length; j++) {
                                if (Integer.parseInt(str1[j]) != 0) {
                                    return true;
                                }
                                if (j == str1.length - 1) {
                                    return false;
                                }

                            }
                            return true;
                        }
                    }
                }
            } else {
                for (int i = 0; i < str1.length; i++) {
                    if (Integer.parseInt(str1[i]) > Integer.parseInt(str2[i])) {
                        return true;
                    } else if (Integer.parseInt(str1[i]) < Integer.parseInt(str2[i])) {
                        return false;

                    } else if (Integer.parseInt(str1[i]) == Integer.parseInt(str2[i])) {
                        if (str1.length == 1) {
                            continue;
                        }
                        if (i == str1.length - 1) {
                            return false;

                        }
                    }

                }
            }
        }
        return false;
    }

测试方法

    public static void main(String[] args) {

        System.out.println(compareVersions("3.0.0.0.0.1.0.1", "3.0.0.0.0.1"));
        System.out.println(compareVersions("3.0.0.0.0.0.1.0", "3.0.0.0.0") + "\n\n\n\n");

        System.out.println(compareVersions("3.0", "3"));
        System.out.println(compareVersions("3.0.0.1", "3.0"));
        System.out.println(compareVersions("3", "3.0") + "\n\n\n\n");

         System.out.println(compareVersions("3.1.1", "3.1"));
         System.out.println(compareVersions("3.1.1", "3.1.1.1"));
         System.out.println(compareVersions("3.1", "3.1.0") + "\n\n\n\n");

         System.out.println(compareVersions("1.1.1", "2.0.0"));
         System.out.println(compareVersions("3.2", "3.3.2") + "\n\n\n\n");

         System.out.println(compareVersions("1.1", "2.0.0"));
         System.out.println(compareVersions("1.1.1", "2.0"));
    }

下面是我自己的需求,根据编号来进行一个排序,

想法是通过比较编号的大小,然后在VO对象里面重写Collections方法针对对象里面的编号字段进行排序

Collections.sort(List, new TaskTemporaryVO.TaskTemporaryVOAsc())

// 排序
	public static class TaskTemporaryVOAsc implements Comparator<TaskTemporaryVO> {
		@Override
		public int compare(TaskTemporaryVO o2, TaskTemporaryVO o1) {
			if (o1 == null) {
				if (o2 == null) {
					return 0;
				} else {
					return -1;
				}
			} else {
				if (o2 == null) {
					return 1;
				} else {
					if (o1.getCode() == null) {
						if (o2.getCode() == null) {
							return 0;
						} else {
							return 1;
						}
					} else {
						if (o2.getCode() == null) {
							return -1;
						} else {

							if (compareVersions(o2.getCode(), o1.getCode())) {
								return 1;
							} else {
								return -1;
							}
						}
					}
				}
			}
		}
	}

小白操作,应该还有问题,正在继续修改中。

仅供个人学习用,侵删

转载:https://blog.csdn.net/MrGraffiti/article/details/50983180

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python可以通过比较版本号大小判断它们的顺序。有多种方法可以实现这个功能。引用\[1\]中的代码使用了一个类来比较两个版本号大小。它首先将版本号转换为列表,并使用0补齐使两个列表的长度相等。然后对列表进行排序,并根据排序后的结果判断版本号大小。如果两个版本号相等,则输出相等的信息;如果第一个版本号小于第二个版本号,则输出小于的信息;否则输出大于的信息。 引用\[2\]中的代码也是用来比较两个版本号大小。它首先定义了一个函数来去除版本号中的前导0,并将大版本按"."切割为子版本列表。然后通过比较两个版本号列表的元素来判断它们的大小。如果两个版本号相等,则返回0;如果第一个版本号小于第二个版本号,则返回-1;否则返回1。 引用\[3\]中的代码也是用来比较两个版本号大小。它将版本号转换为列表,并通过循环比较列表中的元素来判断它们的大小。如果两个版本号相等,则继续比较下一个元素;如果第一个版本号小于第二个版本号,则返回-1;否则返回1。最后,根据列表的长度来判断哪个版本号更高。 综上所述,以上三种方法都可以用来比较两个版本号大小。你可以根据自己的需求选择其中一种方法来使用。 #### 引用[.reference_title] - *1* [python判断2个版本号大小](https://blog.csdn.net/lizy0327/article/details/121164549)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [华为OD机试 - 比较两个版本号大小Java & JS & Python)](https://blog.csdn.net/qfc_128220/article/details/128179974)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [python 比较两个版本号大小](https://blog.csdn.net/tinyjm/article/details/93514261)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值