会先以一个Linux的例子描述native层加载动态链接库的过程, 再从Java层由浅入深分析System.loadLibrary 首先我们知道在Android(Java)中加载一个动态链接库非常简单...# Linux 系统加载动态库过程分析 Android是基于Linux系统的,那么在Linux系统下是如何加载动态链接库的呢?...: man dlopen 如何在Linux环境下生成动态链接库,如何加载并使用动态链接库中的函数?...然后通过下述命令编译成动态链接库: g++ -fPIC -shared caculate.cpp -o libcaculate.so 这样会在同级目录生成一个动态库文件:libcaculate.so...上面就是Linux环境下创建动态库,加载并使用动态库的全部过程。 由于Android基于Linux系统,所以我们有理由猜测Android系统底层也是通过这种方式加载并使用动态库的。
在实现android插件化过程中,在插件代码中加载so时出现了一些问题,因此特地研究了一下android系统中加载so的过程,记录下来,整理成文。...在android系统中,加载so一般会调用System.loadLibrary(name)或者是System.load(path),这两个函数都可以用来加载so文件,区别在于System.loadLibrary...这两个函数本质上都是一样的,只是搜索so的搜索目录略有差别。下面以System.loadLibrary函数为例来分析加载so的实现原理。...的真正的文件路径;2:调用nativeLoad函数去实现真正的so加载;这里会牵扯到一个问题,如何通过so的名称去ClassLoader拿到so真正的文件路径?...so(findSharedLibEntry),如果已经加载过了,那么直接返回即可;如果没有加载,那么重新加载一遍,加载的过程可以用下面的流程来描述:调用dlopen() 打开一个so文件,取得该so的文件句柄
其中,一个大的第三方so文件,经常会让人头痛。那么,能否动态加载.so文件呢?答案是可以的。...原理 我们知道,如果我们在工程中引入一个so文件,当我们用gradle编译打包时,gradle会将我们jniLibs中的so文件,打到APK包中的lib文件夹下。具体可以参考我的上篇博客。...然后我们安装APK时,系统会将APK包lib文件夹中的so文件拷贝到APP的私有目录下。...具体来说就是: /data/user/0/[包名]/app_libs/ 所以,我们可以将想要加载的so文件,在程序运行时,拷贝到APP的私有目录的对应位置中,然后使用 System.load(......); 加载我们需要的so文件。
Linux程序运行找不到动态库.so文件的三种解决办法 方法一:添加环境变量 子招数1. 添加当前用户当前终端的环境变量-临时 export LD_LIBRARY_PATH=/home/czd/......#.so file path 子招数2....#.so file path 使其生效 source /etc/profile 如不能生效,请重启 方法二:复制so文件到lib路径 linux系统的so库一般存储与“/usr/lib/”路径中,可将动态库复制到该路径中...sudo cp liblibtest.so /usr/lib/ 即时生效 方法三:(推荐)添加ldconfig寻找路径 步骤1. 编辑链接配置文件 vim /etc/ld.so.conf 步骤2....执行命令时期生效 sudo ldconfig 程序在运行时寻找so库就会到添加的目录中寻找。 原创文章,转载请注明出处 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
目录 一,内核相关的命令 1、lsmod 列出已经加载的内核模块; 2、modinfo 查看模块信息; 3、modprobe 挂载新模块以及新模块相依赖的模块 4、rmmod 移除已挂载模块;...三,、硬件驱动在系统中的目录; 四、自己编译驱动的办法; 一,内核相关的命令 1、lsmod 列出已经加载的内核模块; lsmod 是列出目前系统中已加载的模块的名称及大小等;另外我们还可以查看 /proc...Y vermagic: 3.10.0-957.el7.x86_64 SMP mod_unload modversions signer: CentOS Linux...或 modprobe.conf 内核模块的开机自动挂载模块一般是位于一个配置文件,一般的Linux发行版本都有 /etc/modules.conf 或 /etc/modprobe.conf 。...比如Fedora Core 4.0 内核模块开机自动加载文件是 /etc/modprobe.conf ;在这个文件中,一般是写入模块的加载命令或模块的别名的定义等;比如我们在modules.conf 中可能会发行类似的一行
二、动态加载so 随着项目业务越来越多,对APK 体积大小要求尽可能的瘦身,通常可以考虑采用在线加载的方式减少最终 apk 安装包的大小。...优图实验室有如下特殊加载要求(6.8商业版已经优化了这里,祥见《LiteAVSDK商业版6.6+,安卓集成动态加载so》)。...image.png 1、这三个so库必需要在本地加载。 image.png 2、这些so库需要按照如下顺序动态加载。...解决办法就是:先把一个32位的so文件打进安装包,其它so库在运行时动态加载,这样App启动的是32位进程,动态加载的so库也是32位版本,运行时就不再闪退。...五、资源 相关文章: LiteAVSDK商业版6.6+,安卓集成动态加载so 动态加载so库的实现方法与问题处理 Android 的 so 文件加载机制提问源码总结参考资料 demo下载
唯一可能的问题,就是先加载了旧的so,之后下载新的so进行了热更新。 我们先看下微视中是否有这种现象。要观察这种现象,我们可以打开linker自身的调试开关,开启so加载的日志。...那么,我们重新复现问题,可以看到如下so加载过程: ? 这个过程表明:旧的so先被加载了,然后下载了新版本的so,并进行了替换。 这个过程有什么问题呢?...掉,就像我们在第二部分删除掉log文件,而依然能用lsof命令看到一样。...通过cp命令替换so; 3. 点击执行native方法; ? 结果确实是crash了: ? 日志如下,是不是很最开始的日志信息一样呢: ? 到此,我们有两种解决办法: 1. ...如果so有升级,先不加载旧的so,等新的so下载完成之后再加载; 2. 可以先加载旧的so,但是下载了新的so之后,要删除旧的so,再进行替换。
so加载到底有什么特殊性。...唯一可能的问题,就是先加载了旧的so,之后下载新的so进行了热更新。 我们先看下微视中是否有这种现象。要观察这种现象,我们可以打开linker自身的调试开关,开启so加载的日志。...掉,就像我们在第二部分删除掉log文件,而依然能用lsof命令看到一样。...方法都是ok的,使用rm+mv替换或者adb push替换也都是ok的,最后再按照错误的方法操作,步骤为: 启动app,点击加载so; 通过cp命令替换so; 点击执行native方法; [图片16.png...; 可以先加载旧的so,但是下载了新的so之后,要删除旧的so,再进行替换。
PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/mysql.so' - libmysqlclient.so.16:...on line 0 ldconfig -v | grep mysql ls -lhrnt /usr/lib64/mysql echo /usr/lib64/mysql >> /etc/ld.so.conf
要使用ndk进行编程,在Java层就必须要对so进行加载。...Java层加载so的函数有两个: System.load(String pathName) System.loadLibraray(String libName) 两个函数的区别就是load函数的参数是...loadLibrary的参数是so的名称,这个so文件必须放在apk的lib目录下,而且so的名称必须去掉前面的lib和后边的“.so”。...return nativeLoad(name, loader, ldLibraryPath); } } 获得libbrary的路径; 调用native函数nativeLoad()进行加载加载...第二件事情:调用LoadNativeLibrary进行加载。
这个方法是在 so 被加载的时候调用的。今天主要从so 的加载看一下 JNI_OnLoad 的调用。...Flutter的so加载 我们先从 Application 的代码看起: FlutterApplication.onCreate; |--FlutterMain.startInitialization(...加载。...so的加载 AndroidP源码: System.loadLibrary(libName); |--Runtime.loadLibrary0(libName,classLoader); |--|--|-...被加载之后会调用 JNI_OnLoad 方法,我们这次反过来看一下 JNI_OnLoad 加载 native 方法。
业务场景有对so实现动态加载/替换的需求,但Java并没有直接动态加载so的机制。本文将深度剖析Java加载so的实现机制,并提出一套Java动态加载so的方案。...这里动态加载so,是指当前so提供服务的时候,需要动态加载另一个同名so,并对旧的so进行替换,而不影响现有服务。...那我们如何实现Java框架中的so动态加载呢? 一、C++如何实现so动态加载 C++框架实现so的动态加载比较简单,通过dlopen得到加载的so的句柄(void *),dlsym获得函数地址。...跟进os::dll_load(),有三个不同实现分别对应三个平台os_linux, os_windows, os_solaris,这里只看os_linux.cpp // ... void * os::dll_load...到这里恍然,dlopen(filename, RTLD_LAZY)即是linux下Java System.load的最终实现,其实跟C++加载动态链接库是一样的。
本系列 Tinker 源码解析基于 Tinker v1.9.12 校验so补丁流程 与加载资源补丁类似,加载so补丁也要先从校验开始看起。...其实总体来说,Tinker 中加载 so 补丁文件的关键代码就一句: System.load(String filePath) tryLoadPatchFilesInternal final boolean...so补丁流程 加载so补丁的入口:TinkerLoadLibrary.loadArmLibrary / TinkerLoadLibrary.loadArmV7Library ,区别就是前者用来加载 armeabi...如果匹配上了,就说明要加载的就是这个 so 文件,调用 System.load ,传入文件路径即可。...所以从 Tinker v1.7.7 之后,提供了一键反射的方案来加载 so 补丁文件。
下面的内容大多都是连接中的,穿插我自己的笔记 牵扯到ELF格式,gcc编译选项待补,简单实用的说明一下,对Linux下的so文件有个实际性的认识。 1.so文件是什么?...这个特性使得在Linux下,升级使得共享库的程序和定位错误变得十分容易。 ...下面的还没细看,汗 4.库的初始化,解析: windows下的动态库加载,卸载都会有初始化函数以及卸载函数来完成库的初始化以及资源回收,linux当然也可以实现。.../e&连续执行两次,那么初始化函数和解析函数也会执行两次,虽然系统只加载了一次libs.so。 如果sleep时候kill 掉后台进程,那么解析函数不会被执行。.../ts 关键就在LD_PRELOAD上了,这个路径指定的so将在所有的so之前加载,并且符号会覆盖后面加载的so文件中的符号。如果可执行文件的权限不合适(SID),这个变量会被忽略。 执行:.
/lib/ld-linux.so.2以及它的64位版本/lib64/ld-linux-x86-64.so.2虽然看起来是共享库文件,但实际上他们可以独立运行。他们的功能是负责动态加载。...它们通过读取可执行文件的头部信息来确定哪些库文件是必须的,以及哪些需要加载。加载完成后,它会通过修正执行文件里的相关的地址指针来和加载的库文件完成动态链接,此时程序就可以运行了。
apk 安装目录下; System.load(String pathName) :参数为 so 库在磁盘中完整的路径,可以加载自定义外部 so 库文件; 使用第三方库ReLinker,有so加载成功、...但是采取常规load方式,改动有点大,底层jar包,第三库不好改加载路径。 在应用启动的时,一次注入本地so路径path,待程序使用过程中so准备后安全加载。(原因后面分析,我们先看下实践) 一....正常加载so使用 有兴趣可以直接查看开源代码:https://github.com/AnyMarvel/ManPinAPP 核心类,修改nativeLibraryDirectories列表,加载需要的so...Android 的 so 文件加载机制 从System.loadlibrary() 方法分析so文件的加载流程,如下图所示: [jufml8v3gw.png?...总结: 到此处,那么so文件的动态加载(也可以叫做So文件的热修复)已经介绍完了,起始还是比较简单的,只是修改了so文件列表的数组映射,加载了需要使用的真实的so文件.
但是采取常规load方式,改动有点大,底层jar包,第三库不好改加载路径。 在应用启动的时,一次注入本地so路径path,待程序使用过程中so准备后安全加载。(原因后面分析,我们先看下实践) 一....正常加载so使用 有兴趣可以直接查看开源代码:https://github.com/AnyMarvel/ManPinAPP 核心类,修改nativeLibraryDirectories列表,加载需要的so...Android 的 so 文件加载机制 从System.loadlibrary() 方法分析so文件的加载流程,如下图所示: ?...(nativeLibraryDirectories存储了so文件加载的映射表,这里相当于修改了应用加载so的列表) 61 /** List of native library directories...总结: 到此处,那么so文件的动态加载(也可以叫做So文件的热修复)已经介绍完了,其实还是比较简单的,只是修改了so文件列表的数组映射,加载了需要使用的真实的so文件.
我想对于静态加载 so 库文件,大家都已经很熟悉了,这里就不多说了。...在 Android 开发中调用动态库文件(*.so)都是通过 jni 的方式,而静态加载往往是在 apk 或 jar 包中调用so文件时,都要将对应 so 文件打包进 apk 或 jar 包。...动态加载的优点 静态加载,不灵活,apk 包有可能大。所以采用动态加载 so 库文件,有以下几点好处: 灵活,so 文件可以动态加载,不是绑定死的,修改方便,so 库有问题,我们可以动态更新。...so 库文件很大的话,采用动态加载可以减少 apk 的包,变小。 其实我们常用第三方 so 库,单个可能没问题,如果多个第三方 so 库文件,同时加载可能会出现冲突,而动态加载就能够解决这一问题。...注意路径陷阱 动态加载 so 库文件,并不是说可以把文件随便存放到某个 sdcard 文件目录下,这样做既不安全,系统也加载不了。
:在执行main程序的时候发现它动态链接了libtest.so,于是会去固定目录尝试加载libaston.so,如果加载失败则会打印以上错误信息。...系统加载so库的思路: ①首先到LD_LIBRARY_PATH这个环境变量所指定的目录下去寻找 ①如果找不到,再去/usr/lib, /lib等专门存放库的目录下寻找 解决方法一: 将libtest.so...如:export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/mnt/hgfs/winshare/so_test 补充:ldd命令 作用:查看一个可执行程序使用了哪些共享库,...如:ldd main,得到: linux-gate.so.1 => (0xb776f000) libtest.so => /usr/lib/libtest.so (0xb7754000...) libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb75a3000) /lib/ld-linux.so.2 (0xb7770000
按App加载so库的正常流程,在编译前就要把so文件放到工程的jniLibs目录,这样会把so直接打包进apk安装包,然后App在启动时就会预先加载so库。...,然后保存到用户目录,并从用户目录加载该so,最后再调用jni方法。...so,只从用户目录加载so文件。...显然上面采用动态加载的App属于第三种情况,此时启动了64位进程,但动态加载的so库却是32位的,所以会闪退。...so库在运行时动态加载,这样App启动的是32位进程,动态加载的so库也是32位版本,运行时就不再闪退; 点此查看Android开发笔记的完整目录
领取专属 10元无门槛券
手把手带您无忧上云