一、String与Int互转
在 Java 中要将 String 类型转化为 int 类型时,需要使用 Integer 类中的 parseInt() 方法或者 valueOf() 方法进行转换。
String str = "123";
int a = Integer.parseInt(str); // 方式1
int b = Integer.valueOf(str).intValue() // 方式2
在转换过程中需要注意:因为字符串中可能会出现非数字的情况,所以在转换的时候需要捕捉处理异常。
1、Integer.parseInt(String)方法:parseInt()是Integer包装类里的一个方法,可以将字符串解析为带符号的整数
注:
(1)使用parseInt()方法时,字符串中的所有字符都必须是数字,但第一个字符可以是减号“ - ”。例:String str="-1234"; 可以转换为 -1234
(2)当String类型中的不是所有字符都为数字时,也会抛出异常:NumberFormatException。
2、Integer.valueOf(String)方法:valueOf()同样是Integer包装类的一个方法,可以将String类型的值转换为int类型的值。这和parseInt()方法相似,它们转换后的输出的结果是相同的。
3、但,Integer.valueOf()和Integer.parseInt()之间还是存在差异的:
valueOf(String)方法会返回Integer类的对象,而parseInt(String)方法返回原始的int值。
4、int转string
String s = String.valueOf(i);
String s = Integer.toString(i);
String s = i + '';
二、Date与String互转
1、Date转为String
SimpleDateFormat f = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String time = f.format(examApply.getCreateTime())
2、String转为Date
参数String类型的格式必须与注释中的日期格式对齐,否则会报错
DateFormat format = new SimpleDateFormat("yyyy-MM-dd"); //日期格式
Date date = format.parse(time);
3、使用数据库类将String转为Date
转换后格式不改变,String类型为Date类型。该类的源码只支持 - 作为分隔符,所以必须使用 - 作为分隔符。 在确定以 - 为分隔符后,此方法相对会简单很多。
Date date =java.sql.Date.valueOf("2021-06-16");
三、BigDecimal 与 int 比较
这里说一个报错:operator > cannot be applied to java.math.BigDecimal,int,BigDecimal无法用int之类的 >、<、=之类的比较。如果使用的话,就会报这个错误。
BigDecimal必须使用compareTo()
方法来比较,它根据两个值的大小分别返回负数、正数和0
,分别表示小于、大于和等于。
而且也需要用 new BigDecimal(0) 转换为 BigDecimal 才可以进行比较。
if(examRoom.getPrice().compareTo(new BigDecimal(0)) == 0){
user.setStatus(ExamApplyStatus.PAYED);
message = "报名成功,请等待审核";
}