java开根号哪里号?

Java实现比较版本号
涉及到客户端的中经常需要用到比较版本号的功能,但是比较版本号又不能完全按照字符串比较的方式去用compareTo之类的方法;
这就需要我们总结版本号的通用规则,设计一个比较算法并封装成通用方法来使用:
通常版本好如:1.3.20.8,6.82..5a/8.5c等;
通用规则就是,先将版本字符串按照点号分割,然后主版本与主版本比较、此版本与此版本比较,如此按序一级一级往后比较,直到有分出大小;
值得注意的是,很多比较版本号的方法都先将字符串转换成int或者double类型,这样做未必通用,因为可能含有字母,如8.5c这样的版本号;
通用的方式依然是将分割后的字符串当做字符串来比较,不过,比较字符串之前,先比较位数;
比较版本号的方法示例:
* 比较版本号的大小,前者大则返回一个正数,后者大返回一个负数,相等则返回0
* @param version1
* @param version2
public static int compareVersion(String version1, String version2) throws Exception {
if (version1 == null || version2 == null) {
throw new Exception(compareVersion error:illegal params.);
String[] versionArray1 = version1.split(\.);//注意此处为正则匹配,不能用.;
String[] versionArray2 = version2.split(\.);
int idx = 0;
int minLength = Math.min(versionArray1.length, versionArray2.length);//取最小长度值
int diff = 0;
while (idx & minLength
&& (diff = versionArray1[idx].length() - versionArray2[idx].length()) == 0//先比较长度
&& (diff = versionArray1[idx].compareTo(versionArray2[idx])) == 0) {//再比较字符
//如果已经分出大小,则直接返回,如果未分出大小,则再比较位数,有子版本的为大;
diff = (diff != 0) ? diff : versionArray1.length - versionArray2.
注意:其中 split 方法入参为正则匹配表达式,不能用.(.在正则表达式里匹配任何值),需要用\.,才算是按点号分割;
这样,先分割成子串数组,再挨个比较子版本号,比较子版本号时,先比较位数,位数大的就大,位数一样时再按字符串比较方式比较;
如果全部比较完(其中一个版本号比较完)之后,再看一下哪个版本号有更更多的子版本号,也就是分割后的数组长度,有子版本号的为大;
这样就比较完善地考虑了各种情况,并比较出版本号大小;包括有字母后缀的也可以使用;
如 9.9, 10.8.8.6 ,如果直接按字符串比较,则会前者大,后者小,而明显是错误的;分割后比较第一个主版本9与10,从位数上,就已经得出结果后者大;
再如 9.9b, 9.8a 等也适用,如果用转换成int或者double的方法就不适用;java中equals和等号(==)的区别浅谈
字体:[ ] 类型:转载 时间:
java中equals和等号(==)的区别浅谈,需要的朋友可以参考一下
java中的数据类型,可分为两类:1.基本数据类型,也称原始数据类型。byte,short,char,int,long,float,double,boolean&& 他们之间的比较,应用双等号(==),比较的是他们的值。 2.复合数据类型(类)&& 当他们用(==)进行比较的时候,比较的是他们在内存中的存放地址,所以,除非是同一个new出来的对象,他们的比较后的结果为true,否则比较后结果为false。JAVA当中所有的类都是继承于Object这个基类的,在Object中的基类中定义了一个equals的方法,这个方法的初始行为是比较对象的内存地 址,但在一些类库当中这个方法被覆盖掉了,如String,Integer,Date在这些类当中equals有其自身的实现,而不再是比较类在堆内存中的存放地址了。&& 对于复合数据类型之间进行equals比较,在没有覆写equals方法的情况下,他们之间的比较还是基于他们在内存中的存放位置的地址值的,因为Object的equals方法也是用双等号(==)进行比较的,所以比较后的结果跟双等号(==)的结果相同。 代码如下:&publicclass TestString { &publicstaticvoid main(String[] args) { &String s1 ="Monday"; &String s2 ="Monday"; &if (s1 == s2) &{ &System.out.println("s1 == s2");} &else{ &System.out.println("s1 != s2");} &} &}编译并运行程序,输出:s1 == s2说明:s1 与 s2 引用同一个 String 对象 -- "Monday"! 2.再稍微改动一下程序,会有更奇怪的发现:
代码如下:publicclass TestString { publicstaticvoid main(String[] args) { String s1 ="Monday";String s2 =new String("Monday");if (s1 == s2) {System.out.println("s1 == s2");} else {System.out.println("s1 != s2");} if (s1.equals(s2)) {System.out.println("s1 equals s2");} else{ System.out.println("s1 not equals s2");}}}我们将s2用new操作符创建 程序输出: s1 != s2 s1 equals s2 说明:s1 s2分别引用了两个"Monday"String对象3. 字符串缓冲池 原来,程序在运行的时候会创建一个字符串缓冲池当使用 s2 = "Monday" 这样的表达是创建字符串的时候,程序首先会在这个String缓冲池中寻找相同值的对象,在第一个程序中,s1先被放到了池中,所以在s2被创建的时候,程序找到了具有相同值的 s1 将s2引用s1所引用的对象"Monday" 第二段程序中,使用了 new 操作符,他明白的告诉程序:"我要一个新的!不要旧的!"于是一个新的"Monday"Sting对象被创建在内存中。他们的值相同,但是位置不同,一个在池中游泳一个在岸边休息。哎呀,真是资源浪费,明明是一样的非要分开做什么呢?4.再次更改程序: 代码如下:publicclass TestString { publicstaticvoid main(String[] args) { String s1 ="Monday";String s2 =new String("Monday");s2 = s2.intern(); if (s1 == s2) {System.out.println("s1 == s2");} else {System.out.println("s1 != s2");} if (s1.equals(s2)){System.out.println("s1 equals s2");} else{ System.out.println("s1 not equals s2");}} }这次加入:s2 = s2.intern(); 程序输出: s1 == s2 s1 equals s2 原 来,(java.lang.String的intern()方法"abc".intern()方法的返回值还是字符串"abc",表面上看起来好像这个方 法没什么用处。但实际上,它做了个小动作:检查字符串池里是否存在"abc"这么一个字符串,如果存在,就返回池里的字符串;如果不存在,该方法会 把"abc"添加到字符串池中,然后再返回它的引用。 )
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具

我要回帖

更多关于 java 根号 的文章

 

随机推荐