一。java中的基本数据类型
二。double和float精度不准的问题
double和float本身确实存在某种缺陷,不能用于精确计算。
解决办法: 用java.math.BigDecimal,通过BigDecimal类可以解决上述问题
ArithUtil是自定义的一个工具类,封装了加减乘除操作。
- package ex;
- import java.math.*;
- public class BigDecimalDemo {
- public static void main(String[] args){
- System.out.println(ArithUtil.add(0.01, 0.05));
- System.out.println(ArithUtil.sub(1.0, 0.42));
- System.out.println(ArithUtil.mul(4.015, 100));
- System.out.println(ArithUtil.div(123.3, 100));
- }
- }
- class ArithUtil{
- private static final int DEF_DIV_SCALE=10;
- private ArithUtil(){}
- public static double add(double d1,double d2){
- BigDecimal b1=new BigDecimal(Double.toString(d1));
- BigDecimal b2=new BigDecimal(Double.toString(d2));
- return b1.add(b2).doubleValue();
- }
- public static double sub(double d1,double d2){
- BigDecimal b1=new BigDecimal(Double.toString(d1));
- BigDecimal b2=new BigDecimal(Double.toString(d2));
- return b1.subtract(b2).doubleValue();
- }
- public static double mul(double d1,double d2){
- BigDecimal b1=new BigDecimal(Double.toString(d1));
- BigDecimal b2=new BigDecimal(Double.toString(d2));
- return b1.multiply(b2).doubleValue();
- }
- public static double div(double d1,double d2){
- return div(d1,d2,DEF_DIV_SCALE);
- }
- public static double div(double d1,double d2,int scale){
- if(scale<0){
- throw new IllegalArgumentException("The scale must be a positive integer or zero");
- }
- BigDecimal b1=new BigDecimal(Double.toString(d1));
- BigDecimal b2=new BigDecimal(Double.toString(d2));
- return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
- }
- }
三。int和Integer区别
int是一个基本数据类型,基本类型不具备面向对象的基本特征,没有属性和方法。
为了面向对象操作的一致性,java为每一种基本类型都提供了相应的封装类型,封装类型属于引用类型,具有方法和属性,利用这些属性和方法可以很方便的实现一些基本类型难以实现的功能。例如将数值转换为字符串,将字符串转换为数值等。
四。强转原则
五。值传递和引用传递区别
1.存储机制:简单类型变量直接在栈内开辟空间存储变量值。引用型变量由引用空间和存储空间构成,引用空间在栈内,存储空间在堆中,负责存储变量值,引用空间存储的是存储空间的首地址。
2.值传递:简单型变量传递的是内容本身,引用变量传递的是引用地址。
六。x+=y和x=x+y区别、&和&&区别(包括|和||)
前一种包含的操作是:“x=x+y”和强制转换两个操作
第二种必须要求左右两边类型一致。
&被称为逻辑与,在计算表达式结果时,表达式每个操作数都要参与计算,然后才得出整个表达式的结果。
&&被称为短路与,从左到右进行计算,如果发现一个false值,就放弃计算,直接将false作为整个表达式的计算结果并返回。(效率更高)
|和||和&/&&情况类似,||碰到true操作数就放弃后续运算,将true作为计算结果并返回。