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;
}
这个方法是比较时间的,无论是日期类型、时间戳、还是时间类型的,只需要传入时间或日期的字符串以及其对应的格式即可比对大小,注释有标明,可以直接拿走使用哦。
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值