java.lang.ClassCastException

0x01. java.lang.ClassCastException

java转换异常

0x02. 类相等的条件

java虚拟机规范:

At run time, a class or interface is determined not by its name alone, but by a pair:
its binary name (§4.2.1) and its defining class loader.

同一个二进制class文件并且是同一个classloader加载.
比如: A.class 是一个三方库里面的, 如果这个三方库被不同的classloader加载那么,必然在转换的时候报:java.lang.ClassCastException异常.

这种问题使用插件框架的场景经常出现

0x03. 真实场景

        View view = LayoutInflater.from(mContext).inflate(R.layout.plugin_xxx_sdk_layout_content, container, false);
        container.addView(view);
        PhotoView imageView = (PhotoView) view.findViewById(R.id.layout_xxx_image); //这里转换出错
  • 0x03.1. 问题:
    PhotoView 不能转换为PhotoView! 很奇怪吧? 如果你开发原生应用的,那么你几乎不会遇到这种异常,但是如果你是对接到插件框架或者你是搞插件化的,那么这类问题是你逃避不了的.

  • 0x03.2. 前置条件
    PhotoView是一个三方库, 我这边提供了两个插件A和B, 插件A和B都引入了这个三方库PhotoView. 京东Android主App的插件框架大概的实现原理:

1.插件具有独立的资源分区(通过修改aapt实现)
2.插件具有自己独立的classloader;
3.插件是用时才加载的;

那么这个时候问题来了, 因为所有的插件都在同一个进程里面, 那么如果插件A先于插件B加载了, 并且执行了上面的代码逻辑(PhotoView的转换那部分), 如果这个时候再去执行插件B的PhotoView转换部分的代码逻辑. 那么必然会抛出异常.

因为他们的ClassLoader不一样.

你可能感兴趣的:(异常,bug-fix)