Object强制转换问题

本文探讨了Java中所有类都继承自Object类的原因,解释了为何有时需要创建Object实例,特别是在线程同步优化中的应用。同时,讨论了Object类非抽象且无须覆盖的方法特性,以及编译器如何根据引用类型判断可调用的方法。通过示例说明了对象装入和取出ArrayList<Object>时类型的转换问题,强调了强制类型转换的使用条件和风险,并介绍了instanceof关键字在类型检查中的作用。
摘要由CSDN通过智能技术生成

Java中,所有的类都继承于Object

  1. 为什么创建出Object的实例?

有时候就是需要一个对象,一个轻量级的对象。常见用途是在线程的同步优化上。

  1. Object并不是抽象类,它没有必须要被覆盖的方法。

编译器是根据引用类型来判断有哪些方法可以调用,而不是根据你确实的类型。

//比如一个Dog类 它有bark()方法  当我们取得dog对象的引用时(比如从某个名为a的ArrayList中拿到)
Object object = a.get(1);
object.bark();  //这是不允许的!!!

而object是根本不会bark()方法的。

当把对象装入ArrayList<Object>时,不管它原来是什么,都只能把它当作Object。

但是再把它取出来时,引用的类型也只会是Object。

也就是说这一放一取,原来的对象就没了。

但是,也有办法可以让它还原,也就是强制转换。

Dog dog = (Dog)object;
dog.bark();//这样就可以了

强制转换怎么用呢? 在我确认这个Object是Dog类的时候才能用,如果用错了,它就会报错(比如我将Object强转为Cat类,它就会报错)。

怎么确认?一方面是自己知道,另一方面是编译器帮助我们确认,用的就是instanceof方法

if (object instanceof Dog){
  Dog dog = (Dog) object;
}//就算object不是Dog,也不用担心强转报错了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值