NDK学习之路(二)--windows系统下实现增量更新

普通更新与增量更新的区别:

普通更新:客户端在冷启动的时候会将一个版本号和渠道号发送到服务器,如果是最新的,则服务器返回false,如果不是则返回false

增量更新:发送版本号到服务器,服务器收到版本号如果不是最新,则服务会根据版本号找到旧的apk地址跟新apk的地址进行合并,生成一个差分包(apk.aptch),生成完成之后再进行下载,下载完之后,客户端本地进行合并生成新的apk包

当前程序的apk被删除:系统在安装apk的时候,会将apk先拷贝到/data/app目录下(没有删除旧的程序就安装新的程序,会在data/app下的名字后面加数字,root后可删除)

 

区别:newApkSize-oldApkSize > 差分包的大小,可以节约服务器成本

 

差分原理(哈夫曼算法):将newapk和oldapk的进制编码进行比较,如果相同则只保留索引到apk.aptch,不同则保存压缩的内容和索引,如图:

 

插件化,热更新,差分包的使用场景;

热更新:有两个不同的模块,比如:不加载classA,重新加载classB(轻量级)

插件化(pluginManager):根据模块的不同复用插件,可以和热更新重用(比较轻量级)

差分包(增量更新):可以只布属差分class或差分插件

 

生成差分包(需下载bsdiff-4.3):

1.新建vs工程,在工程目录下新建两个文件夹(include,src),将basdiff下的。h文件拷贝到include文件夹下,将.c和.cpp拷贝到src文件夹下,将文件夹引入到工程

2.生成.exe文件

3.cmd运行,参数:旧apk,新apk,apk.patch

 

windows服务器自动执行:

1.声明native方法

2.将.exe编辑成dll动态库

    2.1 在bsdiff.cpp导入native的.h文件,导入jni.h和jni_md.h文件(java包里的文件是windows平台的,ndk包下的是linux平台的)

    2.2 传入1个名字和3个参数,跟.exe传入包名一样,转为字符串数组

    2.3 调用bsdiff_main()函数(该函数本身是main函数,如果是生成.exe文件则可以保留函数名,如果生成动态库,则不能使用main做为函数名,所以改成了bsdiff_main),传入数组大小和数组

JNIEXPORT void JNICALL Java_Diff_bsdiff

(JNIEnv *env, jclass clz, jstring old_apk, jstring new_apk, jstring patch) {

        int size = 4;

        char *path[4];

        char *old_path = (char*)env->GetStringUTFChars(old_apk,NULL);

        char *new_path = (char*)env->GetStringUTFChars(new_apk, NULL);

        char *patch_path = (char*)env->GetStringUTFChars(patch, NULL);

        path[0] = "bsdiff";

        path[1] = old_path;

        path[2] = new_path;

        path[3] = patch_path;

        bsdiff_main(size, path);

        env->ReleaseStringUTFChars(old_apk, old_path);

        env->ReleaseStringUTFChars(new_apk, new_path);

        env->ReleaseStringUTFChars(patch, patch_path);

        free(path);

}

linux服务器自动执行:

1.将diff中的.c和.h拷贝到同一文件夹下,修改可执行权限

2.使用gcc命令(需将main函数改名)

3.执行生成的文件,执行方法和windows .exe执行一样

 

引入头文件:右键工程-》属性-》C/C++-》附加包含目录-》编辑-》新建-》选择目录(win32平台或x64平台)

引入第三方包可能出现的问题,出现宏定义错误,可以在右键工程-》属性-》C/C++-》命令行输入-D 错误宏

sdl安全检查错误:关闭安全检查 右键工程-》属性-》C/C++-》常规下的安全检查 改为否

 

android 合并差分包:(不能有main方法,加固后的apk新包与合新旧包并后的apk包的md5值是一致的,所以加固不影响合并)(可以使用 ApplicationInfo context.getPackageManager().getApplicationInfo(packageName, 0).sourceDir;获得当前的安装包)

1.导入bspatch下的.c,.cpp,.h文件(可以用file(GLOB name 目录/*.c)导入文件夹下所有的.c文件,能过${name}导入)(glob:全局)

2.编写native方法,与差分方法一致

3.在bspatch文件里导入.h头文件,编写native方法

    3.1 将路径转为char*

    3.2 定义4个长度的字符串数组

    3.3 像差分包一样,分别将名字,旧包,新包,生成路径传入

    3.4 调用 bspatch_main函数(该函数名字和差分时的函数名一样),传入数组长度,和字符串数组

4.生成完成后安装

/**

* 获取已安装Apk文件的源Apk文件

* 如:/data/app/my.apk

*

* @param context

* @param packageName

* @return

*/

public static String getSourceApkPath(Context context, String packageName) {

    if (TextUtils.isEmpty(packageName))

    return null;



    try {

        ApplicationInfo appInfo = context.getPackageManager()

            .getApplicationInfo(packageName, 0);

        return appInfo.sourceDir;

    } catch (PackageManager.NameNotFoundException e) {

        e.printStackTrace();

    }

    return null;

}

JNIEXPORT void JNICALL Java_jni03_test_com_mybspatch_Patch_bspatch(

    JNIEnv *env,

    jobject jobj,jstring oldApk,jstring newApk,jstring patch) {

    LOGD("%s","jni patch begin");

    int size = 4;

    char *apk[4];

    char *c_old = (char *) (*env)->GetStringUTFChars(env,oldApk, NULL);

    char *c_new = (char *) (*env)->GetStringUTFChars(env,newApk, NULL);
    
    char *c_patch = (char *) (*env)->GetStringUTFChars(env,patch, NULL);

    apk[0] = "patch";

    apk[1] = c_old;

    apk[2] = c_new;

    apk[3] = c_patch;

    bspatch_main(size,apk);

    (*env)->ReleaseStringUTFChars(env,oldApk,c_old);

    (*env)->ReleaseStringUTFChars(env,newApk,c_new);

    (*env)->ReleaseStringUTFChars(env,patch,c_patch);

    free(apk);

    LOGD("%s","jni patch end");

}

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: android-ndk-r12b-windows-x86.zip 是一个 Android NDK 的压缩文件。Android NDK (Native Development Kit) 是一个让开发者能够使用 C 或 C++ 程序语言编写 Android 应用的工具集合。它主要用于开发需要高性能或使用底层库的应用程序。 android-ndk-r12b-windows-x86.zip 针对的是 Windows 系统的 32 位操作系统。该文件包含了 Android NDK 的相关文件和工具,可供开发者使用。开发者可以通过下载该文件,解压缩并配置环境变量,以便在 Windows 上编写和构建 C/C++ 代码的 Android 应用程序。 该压缩文件中包含了编译器、调试器、标准系统库、头文件以及其他构建和调试所需的文件。通过使用该工具集合,开发者可以充分利用 C/C++ 语言的速度和功能,编写高性能、复杂的 Android 应用程序。 同时需要注意的是,该压缩文件适用于 Windows 系统的 32 位操作系统。如果你的设备或操作系统是其他类型的,可能需要下载适用于该设备或操作系统的相应版本。 ### 回答2: android-ndk-r12b-windows-x86.zip 是一个Android NDK(Native Development Kit)的压缩文件NDK是一个用于开发Android平台上原生代码的工具集。它允许开发者在Java平台上编写Android应用程序的同时,通过使用C或C++等编程语言编写高性能和复杂度较高的代码模块。NDK通过将应用程序的代码编译为与硬件平台相关的机器码实现高效执行。 android-ndk-r12b-windows-x86.zip 这个文件是适用于Windows操作系统NDK的压缩文件,特定于x86架构。这意味着该NDK版本适用于基于x86架构的32位执行环境,例如32位的Windows操作系统。 该压缩文件包含了开发者在Windows系统上使用NDK所需的所有文件和工具,如编译器、调试器、库文件等。开发者可以使用这个NDK版本来编写和构建在x86架构上运行的Android应用程序。 通过使用NDK,开发者可以利用C或C++编写更高效和功能强大的代码,也可以重用已有的C/C++代码库。这对于需要执行高计算密集型任务、需要访问底层硬件功能或需要与跨平台C/C++库集成的应用程序非常有用。 总之,android-ndk-r12b-windows-x86.zip 是一个适用于Windows操作系统的Android NDK的压缩文件,特定于x86架构。使用这个NDK版本,开发者可以编写高性能、复杂度较高的代码以实现更强大的Android应用程序。 ### 回答3: android-ndk-r12b-windows-x86.zip是一个用于Windows操作系统的Android NDK(Native Development Kit)软件包。Android NDK是一个开发工具集,可以帮助开发人员使用C和C++语言编写Android应用程序。它提供了一组库和工具,允许开发者直接使用本地代码进行开发。 android-ndk-r12b-windows-x86.zip包含了NDK的安装程序和相关的文件。用户可以通过解压缩这个压缩包来安装NDK。一旦安装完成,开发者就可以在Windows操作系统上使用NDK来开发Android应用程序。这个特定的压缩包适用于x86架构的计算机,这是一种常见的Windows计算机架构。 使用android-ndk-r12b-windows-x86.zip,开发者可以利用NDK的功能来更好地优化他们的Android应用程序。这包括直接使用本机代码编写应用程序的能力,以及访问底层系统功能的能力。通过使用NDK,开发者可以在性能关键的部分使用底层代码,提高应用程序的速度和效率。 android-ndk-r12b-windows-x86.zip是一个方便开发者使用Android NDK的软件包。它使开发者能够充分利用底层功能,并开发出更高效的Android应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值