精华内容
参与话题
问答
  • 分包

    2019-04-13 11:19:00
    项目分层(分包)的作用 程序为什么要分包分层? 以顾客去饭店吃饭案例分析一下: 小饭店: 一个服务员搞定(接待顾客\点菜\炒菜) 大饭店: l迎宾员(是否有预定\ 询问吃中餐还是西餐或者烧烤等\ 几位用餐 \ 领路到...

    项目分层(分包)的作用

    程序为什么要分包分层?

    以顾客去饭店吃饭案例分析一下:

    小饭店: 一个服务员搞定(接待顾客\点菜\炒菜)

    大饭店:

    迎宾员(是否有预定\ 询问吃中餐还是西餐或者烧烤等\ 几位用餐 \ 领路到指定的包间\ 找点菜员为顾客点菜 )

    点菜员(记录顾客点餐内容\ 记录是否有忌口等问题\ 找厨师为顾客炒菜)

    厨师(按照顾客菜肴清单,进行炒菜)

    通过案例发现,当程序规模小的时候,可以一个人全部完成;但程序规模大的时候,一个人难以完成,这时,要采用多人合作的方式来完成程序开发。

    多人合作方式将会碰到工作任务分配问题,这时我们会想,每个人负责完成项目的一块内容就可以了。那么,这一块块内容的划分,就需要我们采用分层(分包)的方式完成了。

    通过下图(用户注册功能)来讲解下,项目中常见的分层(分包)。

     

    l view层作用: 视图层,即项目中的界面

    l controller层作用: 控制层, 获取界面上的数据,为界面设置数据; 将要实现的功能交给业务层处理

    l service层作用: 业务层, 功能的实现, controller控制层和数据访问层DAO交互, 将对数据库的操作交给DAO数据访问层来处理

    l dao层作用: 数据访问层, 用来操作数据库表的数据

    l db数据库: 这里指MySQL

    l domain 实体包: 存放JavaBean

    l tools工具包:存放项目中使用到的工具类

    l test 测试包: 存放项目功能测试的代码

    转载于:https://www.cnblogs.com/gaowc/p/10700126.html

    展开全文
  • uniapp分包demo

    2020-11-03 15:59:30
    分包下支持独立的 static 目录,用来对静态资源进行分包。 uni-app内支持对微信小程序、QQ小程序、百度小程序分包优化,即将静态资源或者js文件放入分包内不占用主包大小。详情请参考:关于分包优化的说明 针对...
  • 移动端项目分包规范 分包的重要性: 在项目中随心所欲的分包将代码放到任意的package中虽然最终不会影响App的功能,但却会存在非常严重的问题,不好的分包策略带来的影响将会一直持续在App的开发迭代周期中,主要...
  • 本文介绍了小程序使用分包的示例代码,分享给大家,具体如下: 官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework/subpackages.html 某些情况下,开发者需要将小程序划分成不同的子包,在构建...
  • 微信分包文件夹微信分包文件夹
  • 原因之一是分包商的能力差。 为了克服上述问题,本研究试图研究识别和控制越南EPC水电项目延误过程的分包商风险。 通过总结越南EPC水电项目以往研究的国际研究成果,结合越南EPC水电项目建设发展的特点,指出了越南...
  • 易语言IOCP分包源码

    2020-07-20 00:35:38
    易语言IOCP分包源码,IOCP分包,子程序_服务器回调,sock处理,客户进入,客户离开,数据到达,子程序_客户回调,窗口2消息处理,数据到达客户,组包数据,解包数据,包结束标志,初始化模块,iocp服务端_启动服务,iocp服务端_停止...
  • dex分包方案

    2015-12-01 14:33:16
    当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象: 1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT 2. 方法数量过多,编译时出错,提示: ...

    当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象

    1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT

    2. 方法数量过多,编译时出错,提示:

    Conversion to Dalvik format failed:Unable to execute dex: method ID not in [0, 0xffff]: 65536  


    出现这种问题的原因是

    1. Android2.3及以前版本用来执行dexopt(用于优化dex文件)的内存只分配了5M

    2. 一个dex文件最多只支持65536个方法。


    针对上述问题,也出现了诸多解决方案,使用的最多的是插件化,即将一些独立的功能做成一个单独的apk,当打开的时候使用DexClassLoader动态加载,然后使用反射机制来调用插件中的类和方法。这固然是一种解决问题的方案:但这种方案存在着以下两个问题:

    1. 插件化只适合一些比较独立的模块;

    2. 必须通过反射机制去调用插件的类和方法,因此,必须搭配一套插件框架来配合使用;


    由于上述问题的存在,通过不断研究,便有了dex分包的解决方案。简单来说,其原理是将编译好的class文件拆分打包成两个dex,绕过dex方法数量的限制以及安装时的检查,在运行时再动态加载第二个dex文件中。faceBook曾经遇到相似的问题,具体可参考:

    https://www.facebook.com/notes/facebook-engineering/under-the-hood-dalvik-patch-for-facebook-for-android/10151345597798920

    文中有这么一段话:

    However, there was no way we could break our app up this way--too many of our classes are accessed directly by the Android framework. Instead, we needed to inject our secondary dex files directly into the system class loader。

    文中说得比较简单,我们来完善一下该方案:除了第一个dex文件(即正常apk包唯一包含的Dex文件),其它dex文件都以资源的方式放在安装包中,并在Application的onCreate回调中被注入到系统的ClassLoader。因此,对于那些在注入之前已经引用到的类(以及它们所在的jar),必须放入第一个Dex文件中。


    下面通过一个简单的demo来讲述dex分包方案,该方案分为两步执行:


    整个demo的目录结构是这样,我打算将SecondActivity,MyContainer以及DropDownView放入第二个dex包中,其它保留在第一个dex包。

    一、编译时分包

    整个编译流程如下:



    除了框出来的两Target,其它都是编译的标准流程。而这两个Target正是我们的分包操作。首先来看看spliteClasses target。



    由于我们这里仅仅是一个demo,因此放到第二个包中的文件很少,就是上面提到的三个文件。分好包之后就要开始生成dex文件,首先打包第一个dex文件: 



    由这里将${classes}(该文件夹下都是要打包到第一个dex的文件)打包生成第一个dex。接着生成第二个dex,并将其打包到资资源文件中:



    可以看到,此时是将${secclasses}中的文件打包生成dex,并将其加入ap文件(打包的资源文件)中。到此,分包完毕,接下来,便来分析一下如何动态将第二个dex包注入系统的ClassLoader。


    二、将dex分包注入ClassLoader

    这里谈到注入,就要谈到Android的ClassLoader体系。



    由上图可以看出,在叶子节点上,我们能使用到的是DexClassLoader和PathClassLoader,通过查阅开发文档,我们发现他们有如下使用场景:

    1. 关于PathClassLoader,文档中写到: Android uses this class for its system class loader and for its application class loader(s),

    由此可知,Android应用就是用它来加载;

    2. DexClass可以加载apk,jar,及dex文件,但PathClassLoader只能加载已安装到系统中(即/data/app目录下)的apk文件。


    知道了两者的使用场景,下面来分析下具体的加载原理,由上图可以看到,两个叶子节点的类都继承BaseDexClassLoader中,而具体的类加载逻辑也在此类中:

    BaseDexClassLoader:  

    [java] view plaincopy在CODE上查看代码片派生到我的代码片

    1. @Override  

    2. protected Class<?> findClass(String name) throws ClassNotFoundException {  

    3.     List<Throwable> suppressedExceptions = new ArrayList<Throwable>();  

    4.     Class c = pathList.findClass(name, suppressedExceptions);  

    5.     if (c == null) {  

    6.         ClassNotFoundException cnfe = new ClassNotFoundException("Didn't find class \"" + name + "\" on path: " + pathList);  

    7.         for (Throwable t : suppressedExceptions) {  

    8.             cnfe.addSuppressed(t);  

    9.        }  

    10.         throw cnfe;  

    11.     }  

    12.      return c;  

    13. }  


    由上述函数可知,当我们需要加载一个class时,实际是从pathList中去需要的,查阅源码,发现pathList是DexPathList类的一个实例。ok,接着去分析DexPathList类中的findClass函数,

    DexPathList:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片

    1. public Class findClass(String name, List<Throwable> suppressed) {  

    2.     for (Element element : dexElements) {  

    3.         DexFile dex = element.dexFile;  

    4.         if (dex != null) {  

    5.             Class clazz = dex.loadClassBinaryName(name, definingContext, suppressed);  

    6.             if (clazz != null) {  

    7.                 return clazz;  

    8.             }  

    9.         }  

    10.    }  

    11.     if (dexElementsSuppressedExceptions != null) {  

    12.         suppressed.addAll(Arrays.asList(dexElementsSuppressedExceptions));  

    13.     }  

    14.     return null;  

    15. }  

    上述函数的大致逻辑为:遍历一个装在dex文件(每个dex文件实际上是一个DexFile对象)的数组(Element数组,Element是一个内部类),然后依次去加载所需要的class文件,直到找到为止。

    看到这里,注入的解决方案也就浮出水面,假如我们将第二个dex文件放入Element数组中,那么在加载第二个dex包中的类时,应该可以直接找到。

    带着这个假设,来完善demo。

    在我们自定义的BaseApplication的onCreate中,我们执行注入操作:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片

    1. public String inject(String libPath) {  

    2.     boolean hasBaseDexClassLoader = true;  

    3.     try {  

    4.         Class.forName("dalvik.system.BaseDexClassLoader");  

    5.     } catch (ClassNotFoundException e) {  

    6.         hasBaseDexClassLoader = false;  

    7.     }  

    8.     if (hasBaseDexClassLoader) {  

    9.         PathClassLoader pathClassLoader = (PathClassLoader)sApplication.getClassLoader();  

    10.         DexClassLoader dexClassLoader = new DexClassLoader(libPath, sApplication.getDir("dex"0).getAbsolutePath(), libPath, sApplication.getClassLoader());  

    11.         try {  

    12.             Object dexElements = combineArray(getDexElements(getPathList(pathClassLoader)), getDexElements(getPathList(dexClassLoader)));  

    13.             Object pathList = getPathList(pathClassLoader);  

    14.             setField(pathList, pathList.getClass(), "dexElements", dexElements);  

    15.             return "SUCCESS";  

    16.         } catch (Throwable e) {  

    17.             e.printStackTrace();  

    18.             return android.util.Log.getStackTraceString(e);  

    19.         }  

    20.     }  

    21.     return "SUCCESS";  

    22. }   

    这是注入的关键函数,分析一下这个函数:

    参数libPath是第二个dex包的文件信息(包含完整路径,我们当初将其打包到了assets目录下),然后将其使用DexClassLoader来加载(这里为什么必须使用DexClassLoader加载,回顾以上的使用场景),然后通过反射获取PathClassLoader中的DexPathList中的Element数组(已加载了第一个dex包,由系统加载),以及DexClassLoader中的DexPathList中的Element数组(刚将第二个dex包加载进去),将两个Element数组合并之后,再将其赋值给PathClassLoader的Element数组,到此,注入完毕。


    现在试着启动app,并在TestUrlActivity(在第一个dex包中)中去启动SecondActivity(在第二个dex包中),启动成功。这种方案是可行。


    但是使用dex分包方案仍然有几个注意点:

    1. 由于第二个dex包是在Application的onCreate中动态注入的,如果dex包过大,会使app的启动速度变慢,因此,在dex分包过程中一定要注意,第二个dex包不宜过大。

    2. 由于上述第一点的限制,假如我们的app越来越臃肿和庞大,往往会采取dex分包方案和插件化方案配合使用,将一些非核心独立功能做成插件加载,核心功能再分包加载。

    展开全文
  • android分包方案

    千次阅读 2014-12-31 16:43:34
    当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象: 1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT 2. 方法数量过多,编译时出错,提示: ...

    当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象

    1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT

    2. 方法数量过多,编译时出错,提示:

    Conversion to Dalvik format failed:Unable to execute dex: method ID not in [0, 0xffff]: 65536  


    出现这种问题的原因是

    1. Android2.3及以前版本用来执行dexopt(用于优化dex文件)的内存只分配了5M

    2. 一个dex文件最多只支持65536个方法。


    针对上述问题,也出现了诸多解决方案,使用的最多的是插件化,即将一些独立的功能做成一个单独的apk,当打开的时候使用DexClassLoader动态加载,然后使用反射机制来调用插件中的类和方法。这固然是一种解决问题的方案:但这种方案存在着以下两个问题:

    1. 插件化只适合一些比较独立的模块;

    2. 必须通过反射机制去调用插件的类和方法,因此,必须搭配一套插件框架来配合使用;


    由于上述问题的存在,通过不断研究,便有了dex分包的解决方案。简单来说,其原理是将编译好的class文件拆分打包成两个dex,绕过dex方法数量的限制以及安装时的检查,在运行时再动态加载第二个dex文件中。faceBook曾经遇到相似的问题,具体可参考:

    https://www.facebook.com/notes/facebook-engineering/under-the-hood-dalvik-patch-for-facebook-for-android/10151345597798920

    文中有这么一段话:

    However, there was no way we could break our app up this way--too many of our classes are accessed directly by the Android framework. Instead, we needed to inject our secondary dex files directly into the system class loader。

    文中说得比较简单,我们来完善一下该方案:除了第一个dex文件(即正常apk包唯一包含的Dex文件),其它dex文件都以资源的方式放在安装包中,并在Application的onCreate回调中被注入到系统的ClassLoader。因此,对于那些在注入之前已经引用到的类(以及它们所在的jar),必须放入第一个Dex文件中。


    下面通过一个简单的demo来讲述dex分包方案,该方案分为两步执行:


    整个demo的目录结构是这样,我打算将SecondActivity,MyContainer以及DropDownView放入第二个dex包中,其它保留在第一个dex包。

    一、编译时分包

    整个编译流程如下:



    除了框出来的两Target,其它都是编译的标准流程。而这两个Target正是我们的分包操作。首先来看看spliteClasses target。



    由于我们这里仅仅是一个demo,因此放到第二个包中的文件很少,就是上面提到的三个文件。分好包之后就要开始生成dex文件,首先打包第一个dex文件: 



    由这里将${classes}(该文件夹下都是要打包到第一个dex的文件)打包生成第一个dex。接着生成第二个dex,并将其打包到资资源文件中:



    可以看到,此时是将${secclasses}中的文件打包生成dex,并将其加入ap文件(打包的资源文件)中。到此,分包完毕,接下来,便来分析一下如何动态将第二个dex包注入系统的ClassLoader。


    二、将dex分包注入ClassLoader

    这里谈到注入,就要谈到Android的ClassLoader体系。



    由上图可以看出,在叶子节点上,我们能使用到的是DexClassLoader和PathClassLoader,通过查阅开发文档,我们发现他们有如下使用场景:

    1. 关于PathClassLoader,文档中写到: Android uses this class for its system class loader and for its application class loader(s),

    由此可知,Android应用就是用它来加载;

    2. DexClass可以加载apk,jar,及dex文件,但PathClassLoader只能加载已安装到系统中(即/data/app目录下)的apk文件。


    知道了两者的使用场景,下面来分析下具体的加载原理,由上图可以看到,两个叶子节点的类都继承BaseDexClassLoader中,而具体的类加载逻辑也在此类中:

    BaseDexClassLoader:  

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
    1. @Override  
    2. protected Class<?> findClass(String name) throws ClassNotFoundException {  
    3.     List<Throwable> suppressedExceptions = new ArrayList<Throwable>();  
    4.     Class c = pathList.findClass(name, suppressedExceptions);  
    5.     if (c == null) {  
    6.         ClassNotFoundException cnfe = new ClassNotFoundException("Didn't find class \"" + name + "\" on path: " + pathList);  
    7.         for (Throwable t : suppressedExceptions) {  
    8.             cnfe.addSuppressed(t);  
    9.        }  
    10.         throw cnfe;  
    11.     }  
    12.      return c;  
    13. }  

    由上述函数可知,当我们需要加载一个class时,实际是从pathList中去需要的,查阅源码,发现pathList是DexPathList类的一个实例。ok,接着去分析DexPathList类中的findClass函数,

    DexPathList:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
    1. public Class findClass(String name, List<Throwable> suppressed) {  
    2.     for (Element element : dexElements) {  
    3.         DexFile dex = element.dexFile;  
    4.         if (dex != null) {  
    5.             Class clazz = dex.loadClassBinaryName(name, definingContext, suppressed);  
    6.             if (clazz != null) {  
    7.                 return clazz;  
    8.             }  
    9.         }  
    10.    }  
    11.     if (dexElementsSuppressedExceptions != null) {  
    12.         suppressed.addAll(Arrays.asList(dexElementsSuppressedExceptions));  
    13.     }  
    14.     return null;  
    15. }  

    上述函数的大致逻辑为:遍历一个装在dex文件(每个dex文件实际上是一个DexFile对象)的数组(Element数组,Element是一个内部类),然后依次去加载所需要的class文件,直到找到为止。

    看到这里,注入的解决方案也就浮出水面,假如我们将第二个dex文件放入Element数组中,那么在加载第二个dex包中的类时,应该可以直接找到。

    带着这个假设,来完善demo。

    在我们自定义的BaseApplication的onCreate中,我们执行注入操作:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
    1. public String inject(String libPath) {  
    2.     boolean hasBaseDexClassLoader = true;  
    3.     try {  
    4.         Class.forName("dalvik.system.BaseDexClassLoader");  
    5.     } catch (ClassNotFoundException e) {  
    6.         hasBaseDexClassLoader = false;  
    7.     }  
    8.     if (hasBaseDexClassLoader) {  
    9.         PathClassLoader pathClassLoader = (PathClassLoader)sApplication.getClassLoader();  
    10.         DexClassLoader dexClassLoader = new DexClassLoader(libPath, sApplication.getDir("dex"0).getAbsolutePath(), libPath, sApplication.getClassLoader());  
    11.         try {  
    12.             Object dexElements = combineArray(getDexElements(getPathList(pathClassLoader)), getDexElements(getPathList(dexClassLoader)));  
    13.             Object pathList = getPathList(pathClassLoader);  
    14.             setField(pathList, pathList.getClass(), "dexElements", dexElements);  
    15.             return "SUCCESS";  
    16.         } catch (Throwable e) {  
    17.             e.printStackTrace();  
    18.             return android.util.Log.getStackTraceString(e);  
    19.         }  
    20.     }  
    21.     return "SUCCESS";  
    22. }   

    这是注入的关键函数,分析一下这个函数:

    参数libPath是第二个dex包的文件信息(包含完整路径,我们当初将其打包到了assets目录下),然后将其使用DexClassLoader来加载(这里为什么必须使用DexClassLoader加载,回顾以上的使用场景),然后通过反射获取PathClassLoader中的DexPathList中的Element数组(已加载了第一个dex包,由系统加载),以及DexClassLoader中的DexPathList中的Element数组(刚将第二个dex包加载进去),将两个Element数组合并之后,再将其赋值给PathClassLoader的Element数组,到此,注入完毕。


    现在试着启动app,并在TestUrlActivity(在第一个dex包中)中去启动SecondActivity(在第二个dex包中),启动成功。这种方案是可行。


    但是使用dex分包方案仍然有几个注意点:

    1. 由于第二个dex包是在Application的onCreate中动态注入的,如果dex包过大,会使app的启动速度变慢,因此,在dex分包过程中一定要注意,第二个dex包不宜过大。

    2. 由于上述第一点的限制,假如我们的app越来越臃肿和庞大,往往会采取dex分包方案和插件化方案配合使用,将一些非核心独立功能做成插件加载,核心功能再分包加载。

    展开全文
  • Dex65536分包相关工具

    2017-09-30 16:13:35
    Eclipse超详细解决安卓Dex65536报错,分包方法 原理其实就是将不重要的jar包集中用ant打包成一个jar包,再用SDK自带工具dx.bat去将这个jar包编译成classes2.dex文件,在APP启动后动态加载这个分包dex
  • uniapp分包 小程序分包

    2020-11-23 17:43:03
    Page.js 配置 "pages": [{ ... //分包 "subPackages": [{ //指定根包 根包在src下创建目录 src/oceanPackage "root": "oceanPackage", "pages": [{ "path": "bulkCargo/shipping", "s

    Page.js 配置

    "pages": [{
    			"path": "pages/index/index",
    			"style": {
    				"navigationBarTitleText": "首页"
    			}
    		}],
    		//分包
    "subPackages": [{
    //指定根包 根包在src下创建目录 src/oceanPackage
    		"root": "oceanPackage",
    		"pages": [{
    				"path": "bulkCargo/shipping",
    				"style": {
    					"navigationBarBackgroundColor": "#FFFFFF",
    					"navigationBarTitleText": "test",
    					"navigationStyle": "custom"
    				}
    			}]	
    

    在这里插入图片描述
    这样配置就完了,记得分包下的路由跳转要写此目录文件名。

    uni.navigateTo({
    					url: `/oceanPackage/index`
    				});
    

    分包后
    在这里插入图片描述

    展开全文
  • 易语言自写分包发送源码系统结构:易语言自写分包发送源码,自写分包发送 ======窗口程序集1 || ||------_按钮1_被单击 || ||------_服务器1_数据到达 || ||------_客户1_数据到达 || ||------_按钮2
  • android studio Multidex多分包问题: 我用android studio向导新建了一个android工程,里边只包含一个MainActivity页面,然后我在gradle里开启multidexEnable true, 也引入了 compile '...
  • zz差分包

    2020-11-28 15:52:22
    zz差分包
  • 微信小程序分包

    2019-03-22 16:14:59
    我标记出来了, 主包和分包 , 2者在同一目录下面, 如果目录出现在主包中出现的路径就不要在分包出现了 这几个图片是官方的,还是需要了解的 下面开始自己做 现在要把这个demo分包 pages是底部的...
  • Android dex分包方案

    千次阅读 2015-11-12 23:11:24
    当一个app的功能越来越复杂,代码量越来越多,也许有一天便会突然遇到下列现象: 1. 生成的apk在2.3以前的机器无法安装,提示INSTALL_FAILED_DEXOPT 2. 方法数量过多,编译时出错,提示: ...
  • 为了提高工程优化问题的寻...函数优化以及分包商选择等组合优化问题可利用该算法进行有效求解。仿真实验结果表明:对于相同的优化问题,改进的并行混沌优化算法可以求得更好的优化解,从而证明该方法具有良好的寻优性能。
  • webpack分包

    千次阅读 2019-09-17 20:12:56
    提示在前:文件中import的文件,不使用依然是会被打进包里的,所以项目中尽量移除没用到的import 文中BundleAnalyzerPlugin是分析打包结果用的 CleanWebpackPlugin是每次打包结果生成前清除之前打包结果的文件夹...
  • weblogic的安装jar包,被分包压缩,解压之后变成文件夹了--求大神解答 直接说问题: 安装的weblogic 的jar,由于大于1G,传到工作电脑上时,被分成3个压缩包 直接解压三个压缩包后,形成了一个文件夹。 想要把它...
  • 分包商管理办法

    2013-07-08 13:18:46
    为提升公司项目管理水平,提升直管项目部的施工能力,实现对分包商的有效管理与控制,特制定本办法。
  • C# TCP Socket 分包传送数据

    热门讨论 2010-08-26 09:08:59
    C# TCP Socket 分包传送数据,这个代码也是从别的地方淘来的,用的还不错。
  • 分包总结

    2005-08-25 09:43:00
    一.背景 1.项目组原来使用的是c++builder进行开发; 2.有自己一套的控件(包括表格, 打印, 和其它小控件); 3.整个项目就只有一个工程, 即编译后的可执行文件, 大小约为15M; 4.由于上头的压力, 项目一般都没有按照...
  • 数据分包

    2017-11-14 22:29:00
    1数据分包 在TCP收数据的时候可能会有一个很大的包,这时候很有可能一次就收不完, 或者说一次收到多个数据包, 二进制分包常用的就是size+body的方式; 为了避免服务器被恶意的攻击, 一般会规定一个包的大小上线, 如果...
  • 分包原则

    2018-07-07 20:13:38
    良好的分包,不仅能使项目更易于维护,也能让新加入的开发人员更快的读懂代码,对于整个系统的层级结构有着十分重要的作用,良好分包的作用可见一斑,因此建议大家在开发项目的过程中一定要注意分包。常用的分包方式...
  • 如何分包

    2019-06-23 14:16:54
    继承 继承时不需要将多个子类分到父类包下: 多重继承 第三方实现子类 这样做的话就把继承关系暴露了出来 组件对象 内部类 推荐使用内部类,内部对象需要在外部对象...并且分包后难以明确上下文,不像内部类明确的...

空空如也

1 2 3 4 5 ... 20
收藏数 5,755
精华内容 2,302
关键字:

分包