Java学习(1)

  • 基本类型与其对应的包装类型之间的赋值使用自动装箱与自动拆箱完成。
    Integer x=5;//自动装箱 Integer x=Integer.valueOf(5);
    x=x+5// x=Integer.valueOf(x.intValue()+5); x.intValue()为装箱操作

  • new Integer(123) 与 Integer.valueOf(123) 的区别在于:
    new Integer(123) 每次都会新建一个对象;
    Integer.valueOf(123) 会使用缓存池中的对象,多次调用会取得同一个对象的引用。

  • valueOf的实现方法:判断值是否在缓存池中,如果在的话就直接返回缓存池的内容。

public static Integer valueOf(int i) {
    if (i >= IntegerCache.low && i <= IntegerCache.high)
        return IntegerCache.cache[i + (-IntegerCache.low)];
    return new Integer(i);
}
  • 编译器会在自动装箱过程调用 valueOf() 方法,因此多个 Integer 实例使用自动装箱来创建并且值相同,那么就会引用相同的对象。
Integer m = 123;
Integer n = 123;
System.out.println(m == n); // true
  • == 和 equals()
    == 判断两个对象的地址是不是相等。
基本数据类型:== 比较的是值
引用数据类型:== 比较的是内存地址
	equals() 判断两个对象是否相等。
情况1:类没有重写 equals() 方法。等价于“==”。 object 的 equals 方法是比较的对象的内存地址
情况2:类重写了 equals() 方法。一般用来比较两个对象的内容,若它们的内容相等,则返回 true (即,认为这两个对象相等)String 中的 equals 方法是被重写过的,所以String 的 equals 方法比较的是对象的值。
  • Java 的参数是以值传递的形式传入方法中,而不是引用传递。
    如果参数是个类对象,那么传参时是将对象的地址以值的方式传递到形参中
  • Java 不能隐式执行向下转型,因为这会使得精度降低。
    // float f = 1.1; //不行
short s1 = 1;
// s1 = s1 + 1;错误
//但是使用 += 或者 ++ 运算符可以执行隐式类型转换。
s1 += 1;
s1++;
//上面的语句相当于将 s1 + 1 的计算结果进行了向下转型:
s1 = (short) (s1 + 1);
  • switch 不支持 long,精度过高。是因为 switch 的设计初衷是对那些只有少数的几个值进行等值判断。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值