java中各种数据类型(非基本类型)的大小比较

   这段时间做了一个验单系统中的筛选功能,由于数据库中存储的是保单的节点,以及节点对应的数据,而筛选规则则是用配置好的规则与节点数据比对,所以用到了2点思维上难以转换的技术点。

1、需将节点作为匹配的条件。
2、需将匹配好的节点数据进行比对。

在此,第一条没有赘述的必要,直接看第二点吧,也就是今天想记录的知识点,希望能帮助到需要帮助的人。

             /**
   * Long型数据比较
   * @param a
   * @param b
   * @return 1:a>=b; 2:a<=b;
   */
  public int compareLong(Long a,Long b){
int s = 0;
if(a.longValue()>=b.longValue()){
s=1;
}
if(a.longValue()<=b.longValue()){
s=2;
}
return s;
}
上面这个方法是对2个Long类型数据进行大小的比较,因为两个Long对象值是否相等,不可以使用双等号进行比较,但可以采用上面的方法进行对比,如果有需要,上面的方法有注释等,可以直接拿走。
******************************************************************
             /**
   * Double类型数据比较
    * @param a
   * @param b
   * @return 1:a>b; -1:a<b; 0:a=b;
   */
  public int compareDouble(Double a,Double b){
BigDecimal data1 = new BigDecimal(a);
BigDecimal data2 = new BigDecimal(b);
return data1.compareTo(data2);
}
上面这个方法是对2个Double类型数据进行大小的比较,因为Double非整型数,运算由于精度问题,可能会有误差,建议使用BigDecimal类型!
BigDecimal的compareTo()在数字上小于、等于或大于 时,返回 -1、0 或 1。
此方法同样可以直接拿走用。
******************************************************************
           /**
* 时间类型比较方法
* @param DATE1  日期或时间类型
* @param DATE2 日期或时间类型
* @param dateType 要比较的时间或日期类型  yyyy-MM-dd hh:mm:ss;  yyyy-MM-dd;  hh:mm:ss;
* @return 1:DATE1>=DATE2; 2:DATE1<=DATE2
*/
  public int compare_date(String DATE1, String DATE2,String dateType) {
        Date dt1 = new Date();
        Date dt2 = new Date();
        int s = 0;
         try {
        DateFormat df1 = new SimpleDateFormat(dateType);
        dt1 = df1.parse(DATE1);
             dt2 = df1.parse(DATE2);
           
             if (dt1.getTime() >= dt2.getTime()) {
                 System.out.println("dt1 在dt2前面");
                 s = 1;
             } else if (dt1.getTime() <= dt2.getTime()) {
                 System.out.println("dt1在dt2后面");
                 s = 2;
             }
         } catch (Exception exception) {
             exception.printStackTrace();
         }
         return s;
    }
这个方法是比较时间的,无论是日期类型、时间戳、还是时间类型的,只需要传入时间或日期的字符串以及其对应的格式即可比对大小,注释有标明,可以直接拿走使用哦。

猜你喜欢

转载自mxl0632.iteye.com/blog/2217665