比较两个版本大小java版

今天接到一个面试,要在线写一个java版本比较的工具。就自己写了一个,万一以后用的到呢,写个博客留下来

该版本适合大小写,字符数字混合,截取的字符串长度不等,这些情况

/**
 * 比较版本大小
 * @author chen
 */
public class Demo01 {
	public static void main(String[] args) {
		String v1 = "v1.21.4A";
		String v2 = "v1.22.4d";
		//比较版本函数
		compareVersion(v1,v2);
	}
	/**
	 * 该方法用于比较版本大小
	 * @param v1 版本v1
	 * @param v2 版本v2
	 */
	public static void compareVersion(String v1,String v2){
		//使用正则表达式分割版本
		String[] v1s = v1.split("\\.");
		String[] v2s = v2.split("\\.");
		//比较正则表达式分割后的string数组
		int result = compareStrings(v1s,v2s);
		//根据结果判断版本大小
		if(result>0){
			System.out.println("v2版本大");
		}else if(result<0){
			System.out.println("v1版本大");
		}else{
			System.out.println("v1版本=v2版本");
		}
	}
	/**
	 * 该方法用于比较正则表达式分割后的string数组
	 * @param v1s 版本1分割后的string数组
	 * @param v2s 版本2分割后的string数组
	 * @return -1 v1版本大,1 v2版本大,0 一样大
	 */
	public static int compareStrings(String[] v1s,String[] v2s){
		
		for(int i=0;i<v1s.length;i++){
			//比较单个字符串大小
			int com = compareChars(v1s[i],v2s[i]);
			if(com!=0){
				return com;
			}
		}
		return 0;
	}
	/**
	 * 该类通过比较单个字符串的hash值大小来得到版本号大小
	 * @param v1s 版本1分割后的string
	 * @param v2s 版本2分割后的string
	 * @return -1 v1版本大,1 v2版本大,0 一样大
	 */
	public static int compareChars(String v1s,String v2s){
		char[] c1 = v1s.toCharArray();
		char[] c2 = v2s.toCharArray();
		//当char数组长度相等时
		if(c1.length==c2.length){
			for (int i = 0; i < c1.length; i++) {
				if(getHashCode(c1[i])>getHashCode(c2[i])){
					return 1;
				}else if(getHashCode(c1[i])<getHashCode(c2[i])){
					return -1;
				}
			}
		}
		//当char数组长度不等时
		if(c1.length<c2.length){
			for (int i = 0; i < c1.length; i++) {
				if(getHashCode(c1[i])>getHashCode(c2[i])){
					return 1;
				}else if(getHashCode(c1[i])<getHashCode(c2[i])){
					return -1;
				}
			}
			return 1;
		}
		//当char数组长度不等时
		if(c1.length>c2.length){
			for (int i = 0; i < c2.length; i++) {
				if(getHashCode(c1[i])>getHashCode(c2[i])){
					return 1;
				}else if(getHashCode(c1[i])<getHashCode(c2[i])){
					return 1;
				}
			}
			return -1;
		}		
		return 0;
	}
	//将char转换小写并获取hashCode值
	public static int getHashCode(char c){
		return String.valueOf(c).toLowerCase().hashCode();
	}

 

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值