日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android 插件化處理方案詳解

瀏覽:150日期:2022-09-19 18:15:08
插件化啟動Activity的過程

Android 插件化處理方案詳解

在宿主里面的AndroidManifest.xml里面注冊一個空的activity

從開始執行execStartActivity到最終將Activity對象new出來這個過程,系統層會去校驗需要啟動的activity的合法性[就是是否有在某個應用的AndroidManifest.xml里面注冊]以及按啟動要求創建activity對象。清晰了這點我們就可以很好的繞過系統的約束,達到我們的目的:【插件中的組件擁有真正生命周期,完全交由系統管理、非反射代理】。 簡單來說方案就兩步: Step1、在開始startActivity的時候將需要啟動的插件組件替換成宿主預先聲明號的。

public ActivityResult execStartActivity(Context who, IBinder contextThread, IBinder token, Activity target, Intent intent, int requestCode, Bundle options) { //如果啟動的是插件的activity組件,這里面將會被替換成宿主預先聲明的 PluginIntentResolver.resolveActivity(intent); return hackInstrumentation.execStartActivity(who, contextThread, token, target, intent, requestCode, ptions);}

Step2、在最終創建activity對象的時候改回成插件組件的。

@Overridepublic Activity newActivity(ClassLoader cl, String className, Intent intent) throws InstantiationException, IllegalAccessException, ClassNotFoundException { ClassLoader orignalCl = cl; String orginalClassName = className; String orignalIntent = intent.toString(); if (ProcessUtil.isPluginProcess()) { // 將PluginStubActivity替換成插件中的activity if (PluginManagerHelper.isStub(className)) { String action = intent.getAction(); if (action != null && action.contains(PluginIntentResolver.CLASS_SEPARATOR)) {String[] targetClassName = action.split(PluginIntentResolver.CLASS_SEPARATOR);String pluginClassName = targetClassName[0];final String pid = intent.getStringExtra(PluginIntentResolver.INTENT_EXTRA_PID).trim();PluginDescriptor pluginDescriptor = TextUtils.isEmpty(pid) ? PluginManagerHelper.getPluginDescriptorByClassName(pluginClassName) : PluginManagerHelper.getPluginDescriptorByPluginId(pid);Class<?> clazz = PluginLoader.loadPluginClassByName(pluginDescriptor, pluginClassName);if (clazz != null) { className = pluginClassName; cl = clazz.getClassLoader(); intent.setExtrasClassLoader(cl); if (targetClassName.length > 1) { // 之前為了傳遞classNae,intent的action被修改過 // 這里再把Action還原到原始的Action intent.setAction(targetClassName[1]); } else { intent.setAction(null); } // 添加一個標記符 intent.addCategory(RELAUNCH_FLAG + className);} else { throw new ClassNotFoundException('pluginClassName : ' + pluginClassName, new Throwable());} } else if (PluginManagerHelper.isExact(className, PluginDescriptor.ACTIVITY)) {// 這個邏輯是為了支持外部app喚起配置了stub_exact的插件ActivityPluginDescriptor pluginDescriptor = PluginManagerHelper.getPluginDescriptorByClassName(className);if (pluginDescriptor != null) { boolean isRunning = PluginLauncher.instance().isRunning(pluginDescriptor.getPackageName()); if (!isRunning) { return waitForLoading(pluginDescriptor); }}Class<?> clazz = PluginLoader.loadPluginClassByName(pluginDescriptor, className);if (clazz != null) { cl = clazz.getClassLoader();} else { throw new ClassNotFoundException('className : ' + className, new Throwable());} } else {// 進入這個分支可能是因為activity重啟了,比如橫豎屏切換,由于上面的分支已經把Action還原到原始到Action了// 這里只能通過之前添加的標記符來查找classNameboolean found = false;Set<String> category = intent.getCategories();if (category != null) { Iterator<String> itr = category.iterator(); while (itr.hasNext()) { String cate = itr.next(); if (cate.startsWith(RELAUNCH_FLAG)) { className = cate.replace(RELAUNCH_FLAG, ''); PluginDescriptor pluginDescriptor = PluginManagerHelper.getPluginDescriptorByClassName(className); if (pluginDescriptor != null) {boolean isRunning = PluginLauncher.instance().isRunning( pluginDescriptor.getPackageName());if (!isRunning) { return waitForLoading(pluginDescriptor);} } Class<?> clazz = PluginLoader.loadPluginClassByName(pluginDescriptor, className); cl = clazz.getClassLoader(); found = true; break; } }}if (!found) { throw new ClassNotFoundException( 'className : ' + className + ', intent : ' + intent.toString(), new Throwable());} } } else { if (cl instanceof PluginClassLoader) {PluginIntentResolver.resolveActivity(intent); } else {// Do Nothing } } } try { Activity activity = super.newActivity(cl, className, intent); if (activity instanceof PluginContainer) { ((PluginContainer) activity).setPluginId(intent.getStringExtra(PluginContainer.FRAGMENT_PLUGIN_ID)); } return activity; } catch (ClassNotFoundException e) { // 收集狀態,便于異常分析 throw new ClassNotFoundException(' orignalCl : ' + orignalCl.toString() + ', orginalClassName : '+ orginalClassName + ', orignalIntent : ' + orignalIntent + ', currentCl : ' + cl.toString()+ ', currentClassName : ' + className + ', currentIntent : ' + intent.toString() + ', process : '+ ProcessUtil.isPluginProcess() + ', isStubActivity : '+ PluginManagerHelper.isStub(orginalClassName) + ', isExact : '+ PluginManagerHelper.isExact(orginalClassName, PluginDescriptor.ACTIVITY), e); }}

方案確實很簡單,不過還有一些收尾工作,就是將創建好的[插件]組件進行一些必要的init操作,比如:在聲明周期onCreate之前進行上下文替換等操作,這些都在插件框架提供的PluginInstrumentionWrapper里面進行完成的,看一下代碼片段:

@Overridepublic void callActivityOnCreate(Activity activity, Bundle icicle) { PluginInjector.injectActivityContext(activity); Intent intent = activity.getIntent(); if (intent != null) { intent.setExtrasClassLoader(activity.getClassLoader()); } if (icicle != null) { icicle.setClassLoader(activity.getClassLoader()); } if (ProcessUtil.isPluginProcess()) { installPluginViewFactory(activity); if (activity instanceof WaitForLoadingPluginActivity) { // NOTHING } else { } if (activity.isChild()) { // 修正TabActivity中的Activity的ContextImpl的packageName Context base = activity.getBaseContext(); while (base instanceof ContextWrapper) {base = ((ContextWrapper) base).getBaseContext(); } if (HackContextImpl.instanceOf(base)) {HackContextImpl impl = new HackContextImpl(base);String packageName = PluginLoader.getApplication().getPackageName();// String packageName1 = activity.getPackageName();impl.setBasePackageName(packageName);impl.setOpPackageName(packageName); } } } super.callActivityOnCreate(activity, icicle); monitor.onActivityCreate(activity);}

到這插件activity組件就被順序的啟動起來了,并且是系統在維護具備完整的生命周期。 組件service、Receiver也是一樣的,只是這兩個組件的攔截點在ActivityThread的Handler成員的回調Callback里面進行的。Application和provider在插件啟動的時候進行加載。

資源沖突的解決方案resources.arsc資源描述符詳解

Android 插件化處理方案詳解

packageId: 包名id 資源類型id:string,drawable,layout,color 偏移:某一種類型的偏移值 解決沖突的方案

由于每個插件的包名是不一致的,可以事先規定某個插件的packageId的值固定,然后修改aapt對其進行編譯固定,就可以保證每個插件分配的值不一樣了。

以上就是Android 插件化處理方案詳解的詳細內容,更多關于Android 插件化處理方案的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美日韩一区二区三区四区| 国产精品一区二区三区av麻| 国产夫妻在线| 精品免费视频| 岛国精品一区| 国产精品99一区二区三区| 麻豆精品少妇| 精品一区二区男人吃奶 | 精品视频一区二区三区在线观看 | 久久久久久一区二区| 精品国产亚洲一区二区三区在线| 麻豆极品一区二区三区| 欧美a级一区二区| 精品亚洲自拍| 精品久久99| 日韩大片在线| 国产精品99一区二区| 久久精品动漫| 国产亚洲毛片| 日本国产亚洲| 麻豆一区二区在线| 亚洲天堂资源| 久久视频精品| 蘑菇福利视频一区播放| 亚洲专区视频| 国产精品毛片久久久| 丁香婷婷久久| 亚洲国产专区| 亚洲精品动态| 欧美一级二级三级视频| 久久一区视频| 国产一区二区中文| 亚洲精品动态| 国产成人精选| 香蕉精品视频在线观看| 久久性天堂网| 久久精品xxxxx| 色乱码一区二区三区网站| 亚洲va中文在线播放免费| 国产农村妇女精品一二区| 精品1区2区3区4区| 欧美日韩精品一区二区三区在线观看| 久久精品国产成人一区二区三区| 日韩国产一区| 婷婷激情综合| 日韩精品一级| 97精品中文字幕| 亚洲主播在线| 久久99精品久久久久久园产越南| 久久久精品久久久久久96| 蜜桃久久久久久久| 精品久久视频| 久久福利精品| 国产成人精品一区二区免费看京| 激情综合自拍| 国产精品片aa在线观看| 欧美日韩国产高清电影| 国产日韩欧美一区| 婷婷亚洲五月| 国产日韩中文在线中文字幕 | 国产精品1区| 午夜国产一区二区| 欧美激情五月| 天堂成人国产精品一区| 精品淫伦v久久水蜜桃| 国产婷婷精品| 91视频久久| 日本成人精品| 激情久久久久久| 久久国内精品视频| 久久久精品日韩| 国产精品综合色区在线观看| 午夜欧美精品久久久久久久| 88久久精品| 日本久久成人网| 日韩av黄色在线| 婷婷久久一区| 国产精品麻豆久久| 国产亚洲人成a在线v网站| 欧美亚洲激情| 国产日韩欧美一区二区三区| 蜜桃国内精品久久久久软件9| 国产免费av国片精品草莓男男| 国产综合婷婷| 成人精品久久| 国产一区 二区| 国产精品日韩久久久| 国产资源在线观看入口av| 亚洲综合欧美| av不卡在线| 日本蜜桃在线观看视频| 国产精品一区毛片| 中文字幕一区二区三区四区久久| 中文在线а√在线8| 国产精品一区二区三区www| 亚洲一区导航| 99热免费精品| 久久要要av| 高清日韩中文字幕| 国产精品videossex| 日本vs亚洲vs韩国一区三区二区| 黄色精品网站| 亚洲欧美日韩高清在线| 国产精品1luya在线播放| 日本亚洲不卡| 最新亚洲国产| 日韩一区二区免费看| 日韩国产一区二区| 欧美激情另类| 欧美好骚综合网| 福利一区和二区| 国产精品nxnn| 国产伦乱精品| 欧美日韩va| 婷婷久久免费视频| 亚洲精品第一| 亚洲a成人v| 天堂精品久久久久| 日韩午夜电影| 怡红院精品视频在线观看极品| 欧美一区二区三区高清视频| 久久天堂av| 成人久久一区| 极品日韩av| 国产视频一区三区| 免费久久精品视频| 美国欧美日韩国产在线播放| 石原莉奈一区二区三区在线观看 | 国产精品日韩| 久久99伊人| 日韩中文字幕麻豆| 一本一本久久| 免费人成黄页网站在线一区二区 | 国产美女精品| 中文字幕日韩高清在线 | 国产精品美女久久久浪潮软件| 怡红院精品视频在线观看极品| 婷婷亚洲五月| 国产精品日韩久久久| 日韩精品一区第一页| 亚洲一级淫片| 国产欧美日韩免费观看| 国产欧美日韩一级| 免费视频一区二区三区在线观看| 精品国产一区二区三区av片| 国模精品一区| 日韩欧美另类一区二区| 国产精品99一区二区| 在线视频精品| 日本不卡在线视频| 久久精品国产亚洲一区二区三区| 岛国av免费在线观看| 极品日韩av| 亚洲精品高潮| 麻豆成人在线观看| 中文另类视频| 亚洲精品激情| 久久99精品久久久野外观看| 国产91欧美| 亚洲天堂久久| 中文字幕日韩欧美精品高清在线| 国产精品视频一区二区三区 | 久草精品视频| 久久久久久久久99精品大| 久久香蕉精品| 国产欧美91| 久久麻豆精品| 青草国产精品久久久久久| 麻豆国产精品视频| 91精品一区二区三区综合在线爱| 日韩午夜av| 国产日韩欧美一区二区三区| 国产精品久久久亚洲一区| 国产在线看片免费视频在线观看| 欧美va天堂| 综合亚洲色图| 精品国产午夜| 国产亚洲毛片在线| 欧美激情麻豆| 性欧美69xoxoxoxo| 国产精品午夜av| 性欧美xxxx免费岛国不卡电影| 日韩精品久久理论片| 中文字幕一区久| 一区二区三区四区精品视频| 美腿丝袜在线亚洲一区| 亚洲韩日在线| 日韩高清三区| 久久国产小视频| 91亚洲精品在看在线观看高清| 精品视频网站| 亚洲三级视频| 美女福利一区二区三区| 日韩中出av| 999久久久国产精品| 久久国产三级| 久久福利影视| 麻豆网站免费在线观看| 日韩在线观看一区二区三区| 日韩精品2区|