交叉编译是什么我就不细说了,我使用arm-linux-gnueabihf-gcc在window端进行交叉编译arm的可执行程序中遇到了许多问题(主要就是链接过程出错,不能找到linux的许多文件等)。而编译一个动态库便只需要些头文件,并没有链接的过程,对环境的依赖大大降低了不少。
首先了解编译
我们要分析一下gcc编译的阶段:
1预编译,主要是将#include 的文件内容添加到主程序
2.编译,将程序编译成汇编语言
3.汇编:将汇编语言的程序编成二级制文件
4.链接:将程序依赖的其他等添加到进来、例如静态库这时就可以将代码添加进来,动态库则是在可执行文件中添加一个链接信息,表示在执行的时候需要该动态库,linux下ldd+可执行文件便可以看到其需要的动态库的链接信息。
动态库和静态库究竟是什么
静态库各人理解就是一系列方法的合集,虽然无法使用ldd查看依赖关系,但是在使用其生成的可执行文件时,还是要添加静态库依赖的一些动态库信息,所以最好让静态库可独立。
动态库不像静态库将代码直接添加进来,而是在生成可执行文件时添加一个链接信息,在运行的时候去检测动态库是否存在,不存在会报错。
操作步骤
所以,我们可以在arm的虚拟环境先编译出一个简单的main程序,在其中调用我们的动态库中的函数main1(),便可以弯曲救国,每次编译只需要编译出一个动态库然后替换下去即可。
1.创建一个库文件hello.c hello.h,写入一个简单的helloworld程序,不用创建main()函数。
2.使用arm-linux-gnueabihf交叉编译出一个arm的动态库libhello.so
3.在虚拟机或者拥有gcc的arm上创建一个main.c,并#include "hello.h",主函数并调用即可!
4.编译(注意添加libhello.so路径不然会报错)之后,在arm执行,若是没有将libhello.so拷贝到适合的位置(例如自动寻找的/usr/lib)下,将会提示没有找到该动态库,拷贝到/usr/lib即可。
注意事项
1.更新程序,只需要更新动态库下发到/usr/lib即可。