Giter Site home page Giter Site logo

android-plugin-framework's Introduction

Android-Plugin-Framework

README: 中文

Android-Plugin-Framework是一个Android插件化框架,用于通过动态加载的方式免安装运行插件apk

最新版本: 'com.github.limpoxe:Android-Plugin-Framework:0.0.73@aar'

此项目主要目标是为了运行非独立插件,而不是任意第三方app。

尽管此框架支持独立插件,但目标并不是为了支持任意三方app,不同于平行空间或应用分身之类的产品。 非独立插件相比任意三方app来说,可以预见到其使用了哪些系统api和特性,而且所有行为都是可以预测的。而任意三方app是不可预测的。 框架的做法是按需hook,即需要用到哪些系统特性和api,就对哪些特性和api提供支持。这种做法对开发非独立插件和二方独立插件而言完全足够。 目前已经添加了对常用特性和api的支持,如需使用的api还未支持请联系作者。

FEATURE

  • 框架透明, 插件开发与普通apk开发无异,无约定约束
  • 支持非独立插件和独立插件(非任意三方)
  • 支持四大组件/Application/Fragment/Accessibility/LaunchMode/so
  • 支持插件Theme/Style,宿主Theme/Style,轻松支持基于主题属性的皮肤切换
  • 支持插件发送Notification/时在RemoteViews中携带插件中的资源(只支持5.x及以上, 且不支持miui8)
  • 支持插件热更新:即在插件模块已经被唤起的情况先安装新版本插件,无需重启插件进程(前提是插件高度内敛,宿主不主动持有插件中的任何对象)
  • 支持全局服务:即插件向容器注册一个服务,其他所有插件已经宿主都获取并调用此服务
  • 支持DataBinding(仅限独立插件)
  • 支持插件WebView加载插件本地HTML文件
  • 支持插件Fragment/View内嵌宿主Activity中
  • 支持FileProvider
  • 支持2.3-12.0

LIMIT

  • 不支持插件Activity转场动画使用插件中的动画资源
  • 不支持插件Manifest中申请权限,所有权限必须预埋到宿主Manifest中
  • 不支持第三方app试图唤起插件中的组件时直接使用插件组件的Intent。 第三方app要唤起插件中的静态组件,例如Activity/service/Provider,必须由宿主程序进行桥接,即此组件需同时预埋到宿主和插件的Manifest中
  • 不支持android.app.NativeActivity
  • 不支持当一个插件依赖另一个插件时,被插件依赖的包含资源
  • 不支持插件中的webview弹出原生Chrome组件 例如通过html的标签设置时间选择器。 说明:是否能支持原生组件取决于系统中使用WebView的实现。 如果是使用的Android System Webview,则可以支持。因为它packageId是以0x3f开头; 如果是使用的Chrome Webview,则不支持。因为它packageId是以0x7f开头,会和插件冲突。 这是采用Public.xml进行资源分组的缺陷。
  • 可能不支持对插件或者宿主进行加壳加固处理,未尝试

HOW TO USE

    buildscript {
        dependencies {
            //gradle-7.5-all
            classpath "com.android.tools.build:gradle:7.4.2"
        }
    }
    
    allprojects {
    		repositories {
    			...
    			maven { url 'https://jitpack.io' }
    		}
    }

宿主侧

1、 新建一个工程,作为宿主工程

2、 在宿主工程的build.gradle文件下添加如下3个配置

    //插件脚本
    apply from: "https://raw.githubusercontent.com/limpoxe/Android-Plugin-Framework/master/FairyPlugin/agp7_2_0/host.gradle"        

    android {
        defaultConfig {
            //这个配置不可省略
            applicationId 宿主app包名        
        }
    }
    dependencies {
        //请务必使用@aar结尾,以中断依赖传递
        implementation('com.github.limpoxe:Android-Plugin-Framework:latest.release@aar')
        //可选,用于支持插件全局函数式服务,不使用全局函数式服务不需要添加此依赖
        //implementation('com.limpoxe.support:android-servicemanager:1.0.5@aar')
    }
    fairy {
        //可选配置,用于指定插件进程名。默认插件进程为单独的进程,进程名为":plugin"
        //若设置为空串或者null即是使用宿主进程作为插件进程
        //pluginProcess = ""
        //pluginProcess = null
        //pluginProcess = ":xxx"
    }

3、 在宿主工程中新建一个类继承自Application类, 并配置到AndroidManifest.xml中并重写这个类的下面2个方法

    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        
        //框架日志开关, 默认false
        FairyGlobal.setLogEnable(true);
        
        //首次加载插件会创建插件对象,比较耗时,通过弹出loading页来过渡。
        //这个方法是设置首次加载插件时, 定制loading页面的UI, 不传即默认没有loading页
        //在宿主中创建任意一个layout传进去即可
        //注意:首次唤起插件组件时,如果是通过startActivityForResult唤起的,如果配置了loading页,
        //则实际是先打开了loading页,再转到目标页面,此时会忽略ForResult的结果。这种情况下应该禁用loading页配置
        FairyGlobal.setLoadingResId(R.layout.loading);
        
        //是否支持插件中使用本地html, 默认false
        FairyGlobal.setLocalHtmlenable(true);
        
        //初始化框架
        PluginLoader.initLoader(this);
    }
    @Override
    public Context getBaseContext() {
        return PluginLoader.fixBaseContextForReceiver(super.getBaseContext());
    }

4、在宿主工程中通过下面3个方法进行最基本的插件操作

    安装: PluginManagerHelper.installPlugin( SDcard上插件apk的路径 );
    卸载: PluginManagerHelper.remove( 插件packageName );
    列表: PluginManagerHelper.getPlugins();

5、通过构造一个插件组件Intent打开插件

例如打开插件的Launcher界面

   Intent launchIntent = getPackageManager().getLaunchIntentForPackage( 插件packageName );			
   startActivity(launchIntent);

宿主编译完成后,会在outputs/distrubites目录下生成一个名为host.bar的基线包,作为编译插件的基线。 以上所有内容及更多详情可以参考Demo

插件侧  

独立插件:

新建一个工程, 作为插件工程,无需任何其他配置,编译出来即可当插件apk安装到宿主中。

非独立插件:

1、新建一个工程, 作为插件工程。

2、在build.gradle中添加如下2个配置

    //插件脚本
    apply from: "https://raw.githubusercontent.com/limpoxe/Android-Plugin-Framework/master/FairyPlugin/agp7_2_0/plugin.gradle"

    android {
        defaultConfig {
            //这个配置不可省略
            applicationId 插件app包名        
        }
    }
    
    dependencies {
        //***这是demo中的示例,请根据自己的实际情况修改,作用是指向插件依赖的宿主基线包***
        //支持文件、maven坐标等写法
        //baselinePatch 'xxx:xxx:xxx@bar'
        //debugBaselinePatch 'xxx:xxx:xxx@bar'
        //releaseBaselinePatch 'xxx:xxx:xxx@bar'
        baselinePatch files(project(':Samples:PluginMain').getBuildDir().absolutePath + '/distributions/host.bar')
    }

完成以上2步后即可编译出非独立插件,以上所有内容及更多详情可以参考Demo

Demo编译方法

a)如果是命令行中:

   cd  Android-Plugin-Framework
   
   ./gradlew clean
  
   ./gradlew :Samples:PluginMain:assembleF1Debug
   
   ./gradlew :Samples:PluginTesBase:assembleF1Debug
   
   ./gradlew assembleF1Debug
   
   ./gradlew :Samples:PluginMain:assembleF1Debug
   
   说明:由于框架、demo宿主和各个demo插件都在同一个工程下,依赖关系互相影响,因此需要一定的编译顺序才能正常运行
   
   第一个assembleF1Debug是为了编译宿主,产生基线bar文件
   
   第二个assembleF1Debug是为了编译基础插件,产生插件apk和jar,基础插件jar会被其他插件依赖
   
   第三个assembleF1Debug是为了编译所有插件,产生插件apk
   
   第四个assembleF1Debug是为了重新编译宿主,将前面编译生成的插件apk内置到宿主的assets目录中,作为内置插件使用
   
   接下来将宿主的out目录下的apk安装到设备上即可
   

b)如果是studio中:

打开studio右侧gradle面板区,点clean、点assembleDebug。不要使用菜单栏的菜单编译。

重要:

    1、由于编译脚本依赖Task.doLast, 使用其他编译方法(如菜单编译)可能不会触发Task.doLast导致编译失败
    
    2、必须先编译宿主,再编译非独立插件。(这也是使用菜单栏编译会失败的原因之一)
       原因很简单,既然是非独立插件,肯定是需要引用宿主的类和资源的。所以编译非独立插件时会用到编译宿主时的输出物

    3、由于宿主和插件在同一个工程中,点击assembleDebug时编译顺序不可控,会导致每次clean后,首次assembleDebug会失败,此时重新编译即可
       可能需要执行3次assembleDebug,
           第一次是编译宿主,产生bar文件,
           第二次是依赖bar编译插件,产生插件文件
           第三次是重新编译宿主,将插件文件内置到宿主assets中
        所以如果使用其他编译方法,请务必仔细阅读build.gradle,了解编译过程和依赖关系后可以自行调整编译脚本,否则可能会失败。

    4、Demo中使用了arm平台的so,若在x86平台上测试Demo可能会有so异常,请自行适配so。

  待插件编译完成后,即可通过宿主在运行时下载插件apk或者将插件apk复制到sdcard调用PluginManagerHelper.installPlugin("插件apk绝对路径")进行插件安装。

通常插件会内置一个版本到宿主中随宿主一起发布,则需要将插件配置到宿主的assets目录下,再编译一次宿主(即上述3中的第三次编译)。 配置方法如下:

    dependencies {
        //支持坐标依赖
        //innerPlugin 'xxx:xxx:xxx@apk'
        innerPlugin '/xx/xx/xx/xx.apk'
    }

增加这个配置以后,宿主在打包时会将这个依赖的插件apk打包到宿主的assets目录中

其他

  1. 使用指南
  2. 原理简介
  3. 使用Public.xml的坑和填坑.
  4. 更新记录

联系作者:

Q:15871365851,添加时请注明插件开发

Q群:116993004,重要:添加前请务必仔细阅读此ReadMe!请务必仔细阅读Demo!

android-plugin-framework's People

Contributors

limpoxe avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

android-plugin-framework's Issues

startActivity

在Fragment里面startActivity会提示没有在manifest里面注册,需要getActivity().startActivity

文档描述不清楚

文档写的很不清楚,光靠文档不明白如何使用,希望以后能把文档写的更加详细

在TabActivity中的内容Activity中注册广播会崩溃

异常日志


06-04 13:20:28.760 2770-2770/com.born.mobile.wom.inside E/AndroidRuntime: FATAL EXCEPTION: main
                                                                          Process: com.born.mobile.wom.inside, PID: 2770
                                                                          java.lang.RuntimeException: Unable to start activity ComponentInfo{com.born.mobile.wom.inside/com.born.mobile.wom.inside.stub.PluginStubActivity0}: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.born.mobile.wom.inside/com.example.pluginstudy.testwidget.tab.Tab1Activity}: java.lang.reflect.UndeclaredThrowableException
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2348)
                                                                              at android.app.ActivityThread.access$1100(ActivityThread.java:142)
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1259)
                                                                              at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41)
                                                                              at android.os.Handler.dispatchMessage(Handler.java:98)
                                                                              at android.os.Looper.loop(Looper.java:136)
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5327)
                                                                              at java.lang.reflect.Method.invokeNative(Native Method)
                                                                              at java.lang.reflect.Method.invoke(Method.java:515)
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:680)
                                                                              at dalvik.system.NativeStart.main(Native Method)
                                                                           Caused by: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.born.mobile.wom.inside/com.example.pluginstudy.testwidget.tab.Tab1Activity}: java.lang.reflect.UndeclaredThrowableException
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
                                                                              at android.app.ActivityThread.startActivityNow(ActivityThread.java:2138)
                                                                              at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:135)
                                                                              at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:347)
                                                                              at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:806)
                                                                              at android.widget.TabHost.setCurrentTab(TabHost.java:439)
                                                                              at android.widget.TabHost.addTab(TabHost.java:259)
                                                                              at com.example.pluginstudy.testwidget.TabHostViewActivity.onCreate(TabHostViewActivity.java:27)
                                                                              at android.app.Activity.performCreate(Activity.java:5285)
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090)
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167)
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262)
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2348) 
                                                                              at android.app.ActivityThread.access$1100(ActivityThread.java:142) 
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1259) 
                                                                              at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41) 
                                                                              at android.os.Handler.dispatchMessage(Handler.java:98) 
                                                                              at android.os.Looper.loop(Looper.java:136) 
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5327) 
                                                                              at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                              at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864) 
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:680) 
                                                                              at dalvik.system.NativeStart.main(Native Method) 
                                                                           Caused by: java.lang.reflect.UndeclaredThrowableException
                                                                              at $Proxy0.registerReceiver(Native Method)
                                                                              at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1545)
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1513)
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1507)
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467)
                                                                              at com.plugin.core.PluginContextTheme.registerReceiver(PluginContextTheme.java:187)
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467)
                                                                              at com.example.pluginstudy.testwidget.tab.Tab1Activity.onCreate(Tab1Activity.java:44)
                                                                              at android.app.Activity.performCreate(Activity.java:5285)
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090)
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167)
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262)
                                                                              at android.app.ActivityThread.startActivityNow(ActivityThread.java:2138) 
                                                                              at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:135) 
                                                                              at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:347) 
                                                                              at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:806) 
                                                                              at android.widget.TabHost.setCurrentTab(TabHost.java:439) 
                                                                              at android.widget.TabHost.addTab(TabHost.java:259) 
                                                                              at com.example.pluginstudy.testwidget.TabHostViewActivity.onCreate(TabHostViewActivity.java:27) 
                                                                              at android.app.Activity.performCreate(Activity.java:5285) 
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090) 
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167) 
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262) 
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2348) 
                                                                              at android.app.ActivityThread.access$1100(ActivityThread.java:142) 
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1259) 
                                                                              at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41) 
                                                                              at android.os.Handler.dispatchMessage(Handler.java:98) 
                                                                              at android.os.Looper.loop(Looper.java:136) 
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5327) 
                                                                              at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                              at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864) 
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:680) 
                                                                              at dalvik.system.NativeStart.main(Native Method) 
                                                                           Caused by: java.lang.reflect.InvocationTargetException
                                                                              at java.lang.reflect.Method.invokeNative(Native Method)
                                                                              at java.lang.reflect.Method.invoke(Method.java:515)
                                                                              at com.plugin.core.proxy.MethodHandler.invoke(MethodHandler.java:37)
                                                                              at $Proxy0.registerReceiver(Native Method) 
                                                                              at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1545) 
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1513) 
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1507) 
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467) 
                                                                              at com.plugin.core.PluginContextTheme.registerReceiver(PluginContextTheme.java:187) 
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467) 
                                                                              at com.example.pluginstudy.testwidget.tab.Tab1Activity.onCreate(Tab1Activity.java:44) 
                                                                              at android.app.Activity.performCreate(Activity.java:5285) 
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090) 
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167) 
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262) 
                                                                              at android.app.ActivityThread.startActivityNow(ActivityThread.java:2138) 
                                                                              at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:135) 
                                                                              at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:347) 
                                                                              at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:806) 
                                                                              at android.widget.TabHost.setCurrentTab(TabHost.java:439) 
                                                                              at android.widget.TabHost.addTab(TabHost.java:259) 
                                                                              at com.example.pluginstudy.testwidget.TabHostViewActivity.onCreate(TabHostViewActivity.java:27) 
                                                                              at android.app.Activity.performCreate(Activity.java:5285) 
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090) 
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167) 
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262) 
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2348) 
                                                                              at android.app.ActivityThread.access$1100(ActivityThread.java:142) 
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1259) 
                                                                              at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41) 
                                                                              at android.os.Handler.dispatchMessage(Handler.java:98) 
                                                                              at android.os.Looper.loop(Looper.java:136) 
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5327) 
                                                                              at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                              at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864) 
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:680) 
                                                                              at dalvik.system.NativeStart.main(Native Method) 
                                                                           Caused by: java.lang.SecurityException: Given caller package com.example.pluginstudy is not running in process ProcessRecord{44cc9660 2770:com.born.mobile.wom.inside/u0a772}
                                                                              at android.os.Parcel.readException(Parcel.java:1468)
                                                                              at android.os.Parcel.readException(Parcel.java:1422)
                                                                              at android.app.ActivityManagerProxy.registerReceiver(ActivityManagerNative.java:2347)
                                                                              at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                              at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                              at com.plugin.core.proxy.MethodHandler.invoke(MethodHandler.java:37) 
                                                                              at $Proxy0.registerReceiver(Native Method) 
                                                                              at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1545) 
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1513) 
                                                                              at android.app.ContextImpl.registerReceiver(ContextImpl.java:1507) 
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467) 
                                                                              at com.plugin.core.PluginContextTheme.registerReceiver(PluginContextTheme.java:187) 
                                                                              at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:467) 
                                                                              at com.example.pluginstudy.testwidget.tab.Tab1Activity.onCreate(Tab1Activity.java:44) 
                                                                              at android.app.Activity.performCreate(Activity.java:5285) 
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090) 
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167) 
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262) 
                                                                              at android.app.ActivityThread.startActivityNow(ActivityThread.java:2138) 
                                                                              at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:135) 
                                                                              at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:347) 
                                                                              at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:806) 
                                                                              at android.widget.TabHost.setCurrentTab(TabHost.java:439) 
                                                                              at android.widget.TabHost.addTab(TabHost.java:259) 
                                                                              at com.example.pluginstudy.testwidget.TabHostViewActivity.onCreate(TabHostViewActivity.java:27) 
                                                                              at android.app.Activity.performCreate(Activity.java:5285) 
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1090) 
                                                                              at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:167) 
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262) 
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2348) 
                                                                              at android.app.ActivityThread.access$1100(ActivityThread.java:142) 
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1259) 
                                                                              at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41) 
                                                                              at android.os.Handler.dispatchMessage(Handler.java:98) 
                                                                              at android.os.Looper.loop(Looper.java:136) 
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5327) 
                                                                              at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                              at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864) 
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:680) 
                                                                              at dalvik.system.NativeStart.main(Native Method) 


getIdentifier(name, type, getPackageName())查找不到资源Id问题

场景描述

友盟分享库在宿主中,插件使用友盟分享时 友盟库会调用getIdentifier方法,传入的是宿主的包名,找不到资源Id(代码已经查看是最新)

调试

在PluginResourceWrapper --> getIdentifier断点调试

  1. 在执行 rClass = this.getClass().getClassLoader().loadClass(className);出现异常
  2. catch后执行 packageName = mPluginDescriptor.getPackageName();
  3. 最后执行return super.getIdentifier(entry, type, packageName); 未找到资源Id

目前我的临时解决方案为

将return super.getIdentifier(entry, type, packageName);
替换为return superGetIdentifier(entry, type, packageName);

private int superGetIdentifier(String name, String type, String packageName) {
        int id = super.getIdentifier(name, type, packageName);
        if (id <= 0) {//找不到资源
            //切换包名,继续查找资源
            if (PluginLoader.getApplicatoin().getPackageName().equals(packageName)) {
                packageName = mPluginDescriptor.getPackageName();
            } else {
                packageName = PluginLoader.getApplicatoin().getPackageName();
            }
            id = super.getIdentifier(name, type, packageName);
        }
        return id;
 }

目前这个方案能解决现有的问题,但是不知道是否会引起其他问题。

master分支Demo无法运行

运行环境:HUAWEI PE-TL10,Android 6.0,API 23
错误日志:
03-23 14:34:37.838 26962-26975/com.example.pluginmain E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:38.039 26989-27002/com.example.pluginmain:plugin E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] local reference table dump:
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Last 10 entries (of 512):
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 511: 0x1304e740 java.lang.Object[](4 elements)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 510: 0x1306c250 java.lang.reflect.Method
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 509: 0x12e092e0 java.lang.String "com.plugin.core.... (45 chars)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 508: 0x12cc7ce0 android.app.ActivityThread$ApplicationThread
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 507: 0x12d864a0 $Proxy3
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 506: 0x12d864a0 $Proxy3
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 505: 0x12f4d0a0 java.lang.Object[](3 elements)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 504: 0x12f4e9a0 java.lang.reflect.Method
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 503: 0x1306b840 java.lang.String "com.example.plug... (22 chars)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 502: 0x12dfd7e0 $Proxy5
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Summary:
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of $Proxy3 (1 unique instances)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 200 of $Proxy5 (1 unique instances)
03-23 14:34:38.636 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 100 of java.lang.Object[](3 elements) (100 unique instances)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.Object[](4 elements)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of java.lang.Class (2 unique instances)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.String[](3 elements)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 104 of java.lang.String (104 unique instances)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 101 of java.lang.reflect.Method (101 unique instances)
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of android.app.ActivityThread$ApplicationThread
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115]
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368] Runtime aborting...
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368]
03-23 14:34:38.637 26989-26989/com.example.pluginmain:plugin A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 26989 (uginmain:plugin)
03-23 14:34:39.219 27029-27042/com.example.pluginmain:plugin E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] local reference table dump:
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Last 10 entries (of 512):
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 511: 0x12ec5bc0 java.lang.Object[](4 elements)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 510: 0x12efbac0 java.lang.reflect.Method
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 509: 0x12e0a350 java.lang.String "com.plugin.core.... (45 chars)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 508: 0x12cca0c0 android.app.ActivityThread$ApplicationThread
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 507: 0x12d86530 $Proxy3
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 506: 0x12d86530 $Proxy3
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 505: 0x12e43560 java.lang.Object[](3 elements)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 504: 0x12e602e0 java.lang.reflect.Method
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 503: 0x12e8bac0 java.lang.String "com.example.plug... (22 chars)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 502: 0x12dfd870 $Proxy5
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Summary:
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of $Proxy3 (1 unique instances)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 200 of $Proxy5 (1 unique instances)
03-23 14:34:39.903 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 100 of java.lang.Object[](3 elements) (100 unique instances)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.Object[](4 elements)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of java.lang.Class (2 unique instances)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.String[](3 elements)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 104 of java.lang.String (104 unique instances)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 101 of java.lang.reflect.Method (101 unique instances)
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of android.app.ActivityThread$ApplicationThread
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115]
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368] Runtime aborting...
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368]
03-23 14:34:39.904 27029-27029/com.example.pluginmain:plugin A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 27029 (uginmain:plugin)
03-23 14:34:40.628 27072-27104/com.example.pluginmain:plugin E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:40.646 27086-27105/com.example.pluginmain E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:41.313 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
03-23 14:34:41.313 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] local reference table dump:
03-23 14:34:41.313 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Last 10 entries (of 512):
03-23 14:34:41.313 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 511: 0x13019160 java.lang.Object[](4 elements)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 510: 0x1301a370 java.lang.reflect.Method
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 509: 0x12e0b350 java.lang.String "com.plugin.core.... (45 chars)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 508: 0x12cca8e0 android.app.ActivityThread$ApplicationThread
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 507: 0x12d885c0 $Proxy3
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 506: 0x12d885c0 $Proxy3
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 505: 0x12f06a40 java.lang.Object[](3 elements)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 504: 0x12f0ea60 java.lang.reflect.Method
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 503: 0x13030500 java.lang.String "com.example.plug... (22 chars)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 502: 0x12dfe900 $Proxy5
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Summary:
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of $Proxy3 (1 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 200 of $Proxy5 (1 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 100 of java.lang.Object[](3 elements) (100 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.Object[](4 elements)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of java.lang.Class (2 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.String[](3 elements)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 104 of java.lang.String (104 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 101 of java.lang.reflect.Method (101 unique instances)
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of android.app.ActivityThread$ApplicationThread
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115]
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368] Runtime aborting...
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368]
03-23 14:34:41.314 27072-27072/com.example.pluginmain:plugin A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 27072 (uginmain:plugin)
03-23 14:34:42.007 27147-27177/com.example.pluginmain:plugin E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:42.091 27163-27179/com.example.pluginmain E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] local reference table dump:
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Last 10 entries (of 512):
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 511: 0x1314bd80 java.lang.Object[](4 elements)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 510: 0x13139610 java.lang.reflect.Method
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 509: 0x12e0d3c0 java.lang.String "com.plugin.core.... (45 chars)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 508: 0x12cdb0c0 android.app.ActivityThread$ApplicationThread
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 507: 0x12d8d6e0 $Proxy3
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 506: 0x12d8d6e0 $Proxy3
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 505: 0x130186a0 java.lang.Object[](3 elements)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 504: 0x12ffed60 java.lang.reflect.Method
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 503: 0x132ea040 java.lang.String "com.example.plug... (22 chars)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 502: 0x12dfda20 $Proxy5
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Summary:
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of $Proxy3 (1 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 200 of $Proxy5 (1 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 100 of java.lang.Object[](3 elements) (100 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.Object[](4 elements)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of java.lang.Class (2 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.String[](3 elements)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 104 of java.lang.String (104 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 101 of java.lang.reflect.Method (101 unique instances)
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of android.app.ActivityThread$ApplicationThread
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115]
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368] Runtime aborting...
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368]
03-23 14:34:42.696 27147-27147/com.example.pluginmain:plugin A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 27147 (uginmain:plugin)
03-23 14:34:43.432 27223-27238/com.example.pluginmain:plugin E/HAL: load: id=gralloc != hmi->id=gralloc
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] JNI ERROR (app bug): local reference table overflow (max=512)
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] local reference table dump:
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Last 10 entries (of 512):
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 511: 0x1301c3c0 java.lang.Object[](4 elements)
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 510: 0x13034f10 java.lang.reflect.Method
03-23 14:34:44.098 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 509: 0x12dd3430 java.lang.String "com.plugin.core.... (45 chars)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 508: 0x12cd8ce0 android.app.ActivityThread$ApplicationThread
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 507: 0x12d8f800 $Proxy3
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 506: 0x12d8f800 $Proxy3
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 505: 0x12f3cda0 java.lang.Object[](3 elements)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 504: 0x12f4b6a0 java.lang.reflect.Method
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 503: 0x12ff0f00 java.lang.String "com.example.plug... (22 chars)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 502: 0x12dffb40 $Proxy5
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] Summary:
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of $Proxy3 (1 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 200 of $Proxy5 (1 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 100 of java.lang.Object[](3 elements) (100 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.Object[](4 elements)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 2 of java.lang.Class (2 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of java.lang.String[](3 elements)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 104 of java.lang.String (104 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 101 of java.lang.reflect.Method (101 unique instances)
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115] 1 of android.app.ActivityThread$ApplicationThread
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/indirect_reference_table.cc:115]
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368] Runtime aborting...
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/art: art/runtime/runtime.cc:368]
03-23 14:34:44.099 27223-27223/com.example.pluginmain:plugin A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 27223 (uginmain:plugin)

编译并运行demo,点击plugintest中的打开PluginNormalFragment奔掉问题

7.979 13589-13589/com.example.pluginmain:plugin E/Log_StackTrace: 记录错误日志
android.view.InflateException: Binary XML file line #76: Binary XML file line #76: Error inflating class com.example.plugintest.view.PluginTestLayout
at android.view.LayoutInflater.inflate(LayoutInflater.java:543)
at android.view.LayoutInflater.inflate(LayoutInflater.java:427)
at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
at com.example.plugintest.fragment.PluginNormalFragment.onCreateView(PluginNormalFragment.java:34)
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2184)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1298)
at android.support.v4.app.FragmentManagerImpl.moveFragmentsToInvisible(FragmentManager.java:2323)
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2136)
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2092)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1998)
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607)
at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1238)
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnStart(PluginInstrumentionWrapper.java:344)
at android.app.Activity.performStart(Activity.java:6320)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2399)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2496)
at android.app.ActivityThread.access$1000(ActivityThread.java:153)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1362)
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40)
at android.os.Handler.dispatchMessage(Handler.java:98)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5457)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629)
Caused by: android.view.InflateException: Binary XML file line #76: Error inflating class com.example.plugintest.view.PluginTestLayout
at android.view.LayoutInflater.createView(LayoutInflater.java:649)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:768)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:708)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:839)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:842)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802)
at android.view.LayoutInflater.inflate(LayoutInflater.java:519)
at android.view.LayoutInflater.inflate(LayoutInflater.java:427) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
at com.example.plugintest.fragment.PluginNormalFragment.onCreateView(PluginNormalFragment.java:34) 
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2184) 
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1298) 
at android.support.v4.app.FragmentManagerImpl.moveFragmentsToInvisible(FragmentManager.java:2323) 
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2136) 
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2092) 
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1998) 
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388) 
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607) 
at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181) 
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1238) 
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnStart(PluginInstrumentionWrapper.java:344) 
at android.app.Activity.performStart(Activity.java:6320) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2399) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2496) 
at android.app.ActivityThread.access$1000(ActivityThread.java:153) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1362) 
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40) 
at android.os.Handler.dispatchMessage(Handler.java:98) 
at android.os.Looper.loop(Looper.java:148) 
at android.app.ActivityThread.main(ActivityThread.java:5457) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629) 
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.newInstance(Native Method)
at android.view.LayoutInflater.createView(LayoutInflater.java:623)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:768) 
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:708) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:839) 
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:842) 
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:519) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:427) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
at com.example.plugintest.fragment.PluginNormalFragment.onCreateView(PluginNormalFragment.java:34) 
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2184) 
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1298) 
at android.support.v4.app.FragmentManagerImpl.moveFragmentsToInvisible(FragmentManager.java:2323) 
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2136) 
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2092) 
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1998) 
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388) 
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607) 
at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181) 
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1238) 
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnStart(PluginInstrumentionWrapper.java:344) 
at android.app.Activity.performStart(Activity.java:6320) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2399) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2496) 
at android.app.ActivityThread.access$1000(ActivityThread.java:153) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1362) 
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40) 
at android.os.Handler.dispatchMessage(Handler.java:98) 
at android.os.Looper.loop(Looper.java:148) 
at android.app.ActivityThread.main(ActivityThread.java:5457) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629) 
Caused by: java.lang.NumberFormatException: Invalid int: "left|right"
at java.lang.Integer.invalidInt(Integer.java:138)
at java.lang.Integer.parse(Integer.java:410)
at java.lang.Integer.parseInt(Integer.java:367)
at com.android.internal.util.XmlUtils.convertValueToInt(XmlUtils.java:133)
at android.content.res.TypedArray.getInt(TypedArray.java:357)
at com.example.plugintest.view.PluginTestLayout.(PluginTestLayout.java:28)
at java.lang.reflect.Constructor.newInstance(Native Method) 
at android.view.LayoutInflater.createView(LayoutInflater.java:623) 
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:768) 
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:708) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:839) 
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:842) 
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:802) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:519) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:427) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
at com.example.plugintest.fragment.PluginNormalFragment.onCreateView(PluginNormalFragment.java:34) 
at android.support.v4.app.Fragment.performCreateView(Fragment.java:2184) 
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1298) 
at android.support.v4.app.FragmentManagerImpl.moveFragmentsToInvisible(FragmentManager.java:2323) 
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2136) 
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2092) 
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1998) 
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388) 
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607) 
at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181) 
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1238) 
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnStart(PluginInstrumentionWrapper.java:344) 
at android.app.Activity.performStart(Activity.java:6320) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2399) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2496) 
at android.app.ActivityThread.access$1000(ActivityThread.java:153) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1362) 
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40) 
at android.os.Handler.dispatchMessage(Handler.java:98) 
at android.os.Looper.loop(Looper.java:148) 
at android.app.ActivityThread.main(ActivityThread.java:5457) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629) 
02-06 17:38:57.979 13589-13589/com.example.pluginmain:plugin D/AndroidRuntime: Shutting down VM

Crash when open weex app as plugin

Hi , I developed an app and use Weex (A framework for building Mobile cross-platform UI by Aliibaba), generate an apk as a plugin, can install successfully, but it crashed when click to open.

在宿主工程的app-Debug.jar中没有生成宿主工程的Class文件,求大神解惑..

  我在Demo项目上使用时,生成了宿主工程的所有Class文件,使用起来没问题,但是在我自己的项目中使用时,在非独立插件中,只能使用到宿主工程的所有依赖库,但是却不能使用宿主工程自己的Class,然后我在宿主工程的app-Debug.jar中找到了很多宿主工程依赖库的Class,却没有一个宿主工程的Class...
  我的宿主工程非常大,使用的依赖库很多,会不会跟这个有关..求大神解答.

Class ref in pre-verified class resolved to unexpected implementation

发现4.x系统有这个问题,以下机型复现
HM 2A 系统4.4.4
CHM-UL00 系统4.4.2
vivo X5Max l 系统4.4.4
三星SCH-I679 系统4.3
三星Galaxy Tab 3 8.0 系统4.2.2

日志
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.demo.solo/com.demo.solo.stub.PluginStubActivityStandard1}: android.view.InflateException: Binary XML file line #8: Error inflating class com.demo.tuna.GuitarTunaView
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2249)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2299)
at android.app.ActivityThread.access$700(ActivityThread.java:154)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1284)
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.view.InflateException: Binary XML file line #8: Error inflating class com.demo.tuna.GuitarTunaView
at android.view.LayoutInflater.createView(LayoutInflater.java:619)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:693)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:752)
at android.view.LayoutInflater.inflate(LayoutInflater.java:495)
at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:288)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:143)
at com.demo.solo.plugin.instrument.TunaActivity.onCreate(TunaActivity.java:47)
at android.app.Activity.performCreate(Activity.java:5255)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:285)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2213)
... 12 more
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
at android.view.LayoutInflater.createView(LayoutInflater.java:593)
... 24 more
Caused by: java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
at com.demo.tuna.InstrumentTunaView.(InstrumentTunaView.java:101)
at com.demo.tuna.GuitarTunaView.(GuitarTunaView.java:19)
... 27 more
android.view.InflateException: Binary XML file line #8: Error inflating class com.demo.tuna.GuitarTunaView
at android.view.LayoutInflater.createView(LayoutInflater.java:619)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:693)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:752)
at android.view.LayoutInflater.inflate(LayoutInflater.java:495)
at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:288)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:143)
at com.demo.solo.plugin.instrument.TunaActivity.onCreate(TunaActivity.java:47)
at android.app.Activity.performCreate(Activity.java:5255)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:285)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2213)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2299)
at android.app.ActivityThread.access$700(ActivityThread.java:154)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1284)
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
at android.view.LayoutInflater.createView(LayoutInflater.java:593)
... 24 more
Caused by: java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
at com.demo.tuna.InstrumentTunaView.(InstrumentTunaView.java:101)
at com.demo.tuna.GuitarTunaView.(GuitarTunaView.java:19)
... 27 more
java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
at android.view.LayoutInflater.createView(LayoutInflater.java:593)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:693)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:752)
at android.view.LayoutInflater.inflate(LayoutInflater.java:495)
at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:288)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:143)
at com.demo.solo.plugin.instrument.TunaActivity.onCreate(TunaActivity.java:47)
at android.app.Activity.performCreate(Activity.java:5255)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:285)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2213)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2299)
at android.app.ActivityThread.access$700(ActivityThread.java:154)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1284)
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
at com.demo.tuna.InstrumentTunaView.(InstrumentTunaView.java:101)
at com.demo.tuna.GuitarTunaView.(GuitarTunaView.java:19)
... 27 more
java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
at com.demo.tuna.InstrumentTunaView.(InstrumentTunaView.java:101)
at com.demo.tuna.GuitarTunaView.(GuitarTunaView.java:19)
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
at android.view.LayoutInflater.createView(LayoutInflater.java:593)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:693)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:752)
at android.view.LayoutInflater.inflate(LayoutInflater.java:495)
at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:288)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:143)
at com.demo.solo.plugin.instrument.TunaActivity.onCreate(TunaActivity.java:47)
at android.app.Activity.performCreate(Activity.java:5255)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097)
at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:285)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2213)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2299)
at android.app.ActivityThread.access$700(ActivityThread.java:154)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1284)
at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalvik.system.NativeStart.main(Native Method)

demo在nexus6p,7.1.1上的crash

nexus6p,7.1.1上的crash
安装完成后打开,点击”打开插件,PluginHelloWorld“,会crash,日志如下。
如果点了最后一个”测试宿主tabActivity内嵌插件Activity“,然后再点击”打开插件,PluginHelloWorld“,就可以正常运行了。
android.view.InflateException: Binary XML file line #9: Binary XML file line #9: Error inflating class org.chromium.chrome.browser.widget.accessibility.AccessibilityTabModelListItem Caused by: android.view.InflateException: Binary XML file line #9: Error inflating class org.chromium.chrome.browser.widget.accessibility.AccessibilityTabModelListItem Caused by: java.lang.ClassNotFoundException: Didn't find class "org.chromium.chrome.browser.widget.accessibility.AccessibilityTabModelListItem" on path: DexPathList[[zip file "/data/user/0/com.example.pluginmain/app_plugin_dir/com.example.pluginhelloworld/1.0.1_2/base-1.apk"],nativeLibraryDirectories=[/data/user/0/com.example.pluginmain/app_plugin_dir/com.example.pluginhelloworld/1.0.1_2/lib, /system/lib, /vendor/lib]] at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) at com.limpoxe.fairy.core.PluginClassLoader.findClass(PluginClassLoader.java:101) at java.lang.ClassLoader.loadClass(ClassLoader.java:380) at java.lang.ClassLoader.loadClass(ClassLoader.java:312) at android.view.LayoutInflater.createView(LayoutInflater.java:609) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:787) at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:727) at android.view.LayoutInflater.inflate(LayoutInflater.java:495) at android.view.LayoutInflater.inflate(LayoutInflater.java:426) at android.view.LayoutInflater.inflate(LayoutInflater.java:377) at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:276) at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:136) at com.example.pluginhelloworld.WelcomeActivity.onCreate(WelcomeActivity.java:52) at android.app.Activity.performCreate(Activity.java:6679) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118) at com.limpoxe.fairy.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:279) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2618) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726) at android.app.ActivityThread.-wrap12(ActivityThread.java) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1477) at com.limpoxe.fairy.core.PluginAppTrace.handleMessage(PluginAppTrace.java:40) at android.os.Handler.dispatchMessage(Handler.java:98) at android.os.Looper.loop(Looper.java:154) at android.app.ActivityThread.main(ActivityThread.java:6119) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

关于编译问题

请问大神,编译官方的demo只需要在as右边的gradle命令里操作PluginMain宿主工程,先clean,再build就可以了是吗?或者大神给个编译的具体流程?跪求,比心♥

插件中启动Activity,Intent带上特定flag会先黑屏再切换

黑屏:
Intent intent = new Intent(this, DesignActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intent);

不黑屏:
Intent intent = new Intent(this, DesignActivity.class);
startActivity(intent);

看起了是有什么耗时操作短暂阻塞了主线程

设置theme时,android_content_AssetManager_applyThemeStyle 没有返回

在加载我自己定义的apk,在启动activity时,
发现在调用 resetActivityContext 函数时,
这一段代码
// 重设theme
if (pluginAppTheme != 0) {
RefInvoker.setFieldObject(activity, ContextThemeWrapper.class.getName(), android_content_ContextThemeWrapper_mTheme, null);
activity.setTheme(pluginAppTheme);
}
在运行时,有点像死锁,不过线程的状态还是RUNNABLE,但 activity.setTheme(pluginAppTheme);这语句就是不返回。 手机是华为的荣耀4. 应该是调用native的方法android_content_AssetManager_applyThemeStyle没有返回,一直在运行。

"<1> main@830026030872" prio=5 runnable
java.lang.Thread.State: RUNNABLE
at android.content.res.AssetManager.applyThemeStyle(AssetManager.java:-1)
at android.content.res.Resources$Theme.applyStyle(Resources.java:1256)
at android.view.ContextThemeWrapper.onApplyThemeResource(ContextThemeWrapper.java:132)
at android.app.Activity.onApplyThemeResource(Activity.java:3413)
at android.view.ContextThemeWrapper.initializeTheme(ContextThemeWrapper.java:144)
at android.view.ContextThemeWrapper.setTheme(ContextThemeWrapper.java:89)
at android.support.v7.app.AppCompatActivity.setTheme(AppCompatActivity.java:89)
at com.plugin.core.PluginInjector.resetActivityContext(PluginInjector.java:221)
at com.plugin.core.PluginInjector.injectActivityContext(PluginInjector.java:185)
at com.plugin.core.PluginInstrumentionWrapper.callActivityOnCreate(PluginInstrumentionWrapper.java:145)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2228)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2313)
at android.app.ActivityThread.access$1100(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1238)
at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41)
at android.os.Handler.dispatchMessage(Handler.java:98)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5336)
at java.lang.reflect.Method.invokeNative(Method.java:-1)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:871)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:687)
at dalvik.system.NativeStart.main(NativeStart.java:-1)

"<7> FinalizerDaemon@830030521168" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at java.lang.Object.wait(Object.java:-1)
at java.lang.Object.wait(Object.java:401)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:102)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:73)
at java.lang.Daemons$FinalizerDaemon.run(Daemons.java:170)
at java.lang.Thread.run(Thread.java:841)

"<8> FinalizerWatchdogDaemon@830030521600" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at java.lang.Object.wait(Object.java:-1)
at java.lang.Object.wait(Object.java:364)
at java.lang.Daemons$FinalizerWatchdogDaemon.waitForObject(Daemons.java:230)
at java.lang.Daemons$FinalizerWatchdogDaemon.run(Daemons.java:207)
at java.lang.Thread.run(Thread.java:841)

"<6> ReferenceQueueDaemon@830030520808" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at java.lang.Object.wait(Object.java:-1)
at java.lang.Object.wait(Object.java:364)
at java.lang.Daemons$ReferenceQueueDaemon.run(Daemons.java:130)
at java.lang.Thread.run(Thread.java:841)

"<10> Binder_2@830030544912" prio=5 runnable
java.lang.Thread.State: RUNNABLE
at dalvik.system.NativeStart.run(NativeStart.java:-1)

"<9> Binder_1@830030544672" prio=5 runnable
java.lang.Thread.State: RUNNABLE
at dalvik.system.NativeStart.run(NativeStart.java:-1)

"<5> Compiler@830030520568" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at dalvik.system.NativeStart.run(NativeStart.java:-1)

"<3> Signal Catcher@830030520088" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at dalvik.system.NativeStart.run(NativeStart.java:-1)

"<2> GC@830030519864" daemon prio=5 waiting
java.lang.Thread.State: WAITING
at dalvik.system.NativeStart.run(NativeStart.java:-1)

调用new AlertDialog.Builder(),手机重启

修改 PluginTest 工程下的 com.example.plugintest.fragment.PluginNormalFragment 这个类,在 public void onClick(View v) 函数的最开头位置,加入如下测试代码:

    new AlertDialog.Builder(getContext()).setTitle("测试测试").
            setPositiveButton("确定", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    dialog.dismiss();
                    Toast.makeText(getContext(), "你点了确定",
                            Toast.LENGTH_SHORT).show();
                }
            }).
            setNegativeButton("取消", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    dialog.dismiss();
                }
            }).show();

然后打开测试页面,点击“打开PLUGINNORMALFRAGMENT”,继续点击“来自插件的文字”,手机重启。

手机型号:华为X1 和 华为荣耀6PLUS,Android版本:4.4.2

WaitForLoadingPluginActivity NPE

java.lang.NullPointerException

Attempt to invoke virtual method 'android.content.res.Resources$Theme android.content.res.Resources.newTheme()' on a null object reference
com.limpoxe.fairy.core.d.c(PluginContextTheme.java:140)
com.limpoxe.fairy.core.d.setTheme(PluginContextTheme.java:99)
com.limpoxe.fairy.core.PluginLauncher.startPlugin(PluginLauncher.java:121)
com.limpoxe.fairy.core.loading.WaitForLoadingPluginActivity$1.run(WaitForLoadingPluginActivity.java:72)
java.lang.Thread.run(Thread.java:818)

出现该问题的都是OPPO机器

java.lang.ClassNotFoundException

我写了个测试工程,然后把apk包放进去发现提示MainActivity找不到类。我把你的sample里面的helloworld放到独立工程中打包放到assert里面,提示Applicaiton找不到

Theme.AppCompat.Light 报错

您好:
我将你的工程clone下来,plugintest的style.xml下的Theme.AppCompat.Light 报错请问什么原因?
其次,wxsdklibrary下的com.plugin.core.annotation.ComponentContainer导入错误,编译报如下错误:

  • Exception is:
    org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':wxsdklibrary:compileReleaseJavaWithJavac'.
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:69)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:46)
    at org.gradle.api.internal.tasks.execution.PostExecutionAnalysisTaskExecuter.execute(PostExecutionAnalysisTaskExecuter.java:35)
    at org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:64)
    at org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:58)
    at org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:52)
    at org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52)
    at org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:53)
    at org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:203)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:185)
    at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.processTask(AbstractTaskPlanExecutor.java:62)
    at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.run(AbstractTaskPlanExecutor.java:50)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor.process(DefaultTaskPlanExecutor.java:25)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter.execute(DefaultTaskGraphExecuter.java:110)
    at org.gradle.execution.SelectedTaskExecutionAction.execute(SelectedTaskExecutionAction.java:37)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:37)
    at org.gradle.execution.DefaultBuildExecuter.access$000(DefaultBuildExecuter.java:23)
    at org.gradle.execution.DefaultBuildExecuter$1.proceed(DefaultBuildExecuter.java:43)
    at org.gradle.execution.DryRunBuildExecutionAction.execute(DryRunBuildExecutionAction.java:32)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:37)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:30)
    at org.gradle.initialization.DefaultGradleLauncher$4.run(DefaultGradleLauncher.java:154)
    at org.gradle.internal.Factories$1.create(Factories.java:22)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:52)
    at org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:151)
    at org.gradle.initialization.DefaultGradleLauncher.access$200(DefaultGradleLauncher.java:32)
    at org.gradle.initialization.DefaultGradleLauncher$1.create(DefaultGradleLauncher.java:99)
    at org.gradle.initialization.DefaultGradleLauncher$1.create(DefaultGradleLauncher.java:93)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:62)
    at org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:93)
    at org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:82)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:94)
    at org.gradle.tooling.internal.provider.ExecuteBuildActionRunner.run(ExecuteBuildActionRunner.java:28)
    at org.gradle.launcher.exec.ChainingBuildActionRunner.run(ChainingBuildActionRunner.java:35)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:43)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:28)
    at org.gradle.launcher.exec.ContinuousBuildActionExecuter.execute(ContinuousBuildActionExecuter.java:77)
    at org.gradle.launcher.exec.ContinuousBuildActionExecuter.execute(ContinuousBuildActionExecuter.java:47)
    at org.gradle.launcher.exec.DaemonUsageSuggestingBuildActionExecuter.execute(DaemonUsageSuggestingBuildActionExecuter.java:51)
    at org.gradle.launcher.exec.DaemonUsageSuggestingBuildActionExecuter.execute(DaemonUsageSuggestingBuildActionExecuter.java:28)
    at org.gradle.launcher.cli.RunBuildAction.run(RunBuildAction.java:43)
    at org.gradle.internal.Actions$RunnableActionAdapter.execute(Actions.java:170)
    at org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:237)
    at org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:210)
    at org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:35)
    at org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:24)
    at org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:206)
    at org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:169)
    at org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:33)
    at org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:22)
    at org.gradle.launcher.Main.doAction(Main.java:33)
    at org.gradle.launcher.bootstrap.EntryPoint.run(EntryPoint.java:45)
    at org.gradle.launcher.bootstrap.ProcessBootstrap.runNoExit(ProcessBootstrap.java:54)
    at org.gradle.launcher.bootstrap.ProcessBootstrap.run(ProcessBootstrap.java:35)
    at org.gradle.launcher.GradleMain.main(GradleMain.java:23)
    Caused by: org.gradle.api.internal.tasks.compile.CompilationFailedException: Compilation failed; see the compiler error output for details.
    请帮忙看一下。

无法处理xml定义的android:onClick点击事件

插件中的布局文件如果在view里定义了android:onClick属性,运行时会crash
错误信息如下:

java.lang.IllegalStateException: Could not find method buttonOnclick(View) in a parent or ancestor Context for android:onClick attribute defined on view class android.widget.Button with id 'btn_comment'
at android.view.View$DeclaredOnClickListener.resolveMethod(View.java:4767)
at android.view.View$DeclaredOnClickListener.onClick(View.java:4731)
at android.view.View.performClick(View.java:5697)
at android.widget.TextView.performClick(TextView.java:10795)
at android.view.View$PerformClick.run(View.java:22526)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:158)
at android.app.ActivityThread.main(ActivityThread.java:7197)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1232)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1122)

某些机型插件中发送自定义布局的Notification会出现异常

出问题机型

华为Mate8 NXT-AL10 系统: 6.0
华为SCL-AL00 系统:5.1.1
华为MT7-TL10 系统: 6.0

问题描述

发送自定义布局通知出现异常,可能会出现跳转黑屏、邮件、短信、手机主屏的情况


###异常日志

android.app.RemoteServiceException: Bad notification posted from package com.born.mobile.wom.inside: Couldn't expand RemoteViews for: StatusBarNotification(pkg=com.born.mobile.wom.inside user=UserHandle{0} id=1 tag=null score=0 key=0|com.born.mobile.wom.inside|1|null|10192: Notification(pri=0 contentView=com.born.mobile.wom.inside/0x7f040057 vibrate=null sound=null tick defaults=0x0 flags=0x10 color=0x00000000 vis=PRIVATE))
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1532)
    at com.plugin.core.PluginAppTrace.handleMessage(PluginAppTrace.java:41)
    at android.os.Handler.dispatchMessage(Handler.java:98)
    at android.os.Looper.loop(Looper.java:150)
    at android.app.ActivityThread.main(ActivityThread.java:5546)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:682)

关于数据库

Hi ! 请问插件和插件之间,插件和宿主之间可以互访数据库吗?

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.