linux .so动态库makefile的嵌套调用

1、动态库的编译

下面通过一个例子来介绍如何生成一个动态库。这里有一个头文件:test.h,三个.c文件:test_a.c、

test_b.c、test_c.c,我们将这几个文件编译成一个动态库:libtest.so。

test.h: 

#include   "stdio.h"

void test_a();

void test_b();

void test_c();

 

test_a.c: 

#include "test.h" 

void test_a()

{

        printf("this is in test_a.../n");

}

 

test_b.c:

#include "test.h"

void test_b()

{

         printf("this is in test_b.../n");

}

 

test_a.c:

#include "test.h"

void test_c()

{

          printf("this is in test_c.../n");

}

 

将这几个文件编译成一个动态库:libtest.so

 $ gcc test_a.c test_b.c test_c.c -fPIC -shared -o libtest.so


 

2、动态库的链接

在1、中,我们已经成功生成了一个自己的动态链接库libtest.so,下面我们通过一个程序来调用这个库

里的函数。程序的源文件为:test.c。

test.c:

#include "test.h"

int main()

{

         test_a();

         test_b();

         test_c();

         return 0;

}

 

l 将test.c与动态库libtest.so链接生成执行文件test:

 $ gcc test.c -L. -ltest -o test

 

l 测试是否动态连接,如果列出libtest.so,那么应该是连接正常了

 $ ldd test

 

l 执行test,可以看到它是如何调用动态库中的函数的。

 

3、编译参数解析
最主要的是GCC命令行的一个选项:
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导

出符号),不用该标志外部程序无法连接。相当于一个可执行文件

l -fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通

过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。

l -L.:表示要连接的库在当前目录中

l -ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确

定库的名称

l LD_LIBRARY_PATH:这个环境变量指示动态连接器可以装载动态库的路径。

l 当然如果有root权限的话,可以修改/etc/ld.so.conf文件,然后调用 /sbin/ldconfig来达到同样的目

的,不过如果没有root权限,那么只能采用输出LD_LIBRARY_PATH的方法了。

 

4、注意

调用动态库的时候有几个问题会经常碰到,有时,明明已经将库的头文件所在目录 通过 “-I” include

进来了,库所在文件通过 “-L”参数引导,并指定了“-l”的库名,但通过ldd命令察看时,就是死活找

不到你指定链接的so文件,这时你要作的就是通过修改 LD_LIBRARY_PATH或者/etc/ld.so.conf文件来指

定动态库的目录。通常这样做就可以解决库无法链接的问题了。

 


********************
如果在打印出现的信息中,你发现有一行: libtest.so => not found
     则表明链接程序找不到我们的libtest.so文件哦,为什么呢?因为链接程序只寻找固定目录,例

如/lib目录。如果我们的当前目录是诸如/home/yls/aaa/bbb/ccc这种目录,那么人家是不会主动了解到

的。
     怎么办?办法一:把libtest.so拷贝到链接程序的搜索路径目录下。
                  办法二:设置环境变量LD_LIBRARY_PATH,增加当前路径到该变量中。
     看看现在LD_LIBRARY_PATH有什么内容吧?

1、执行echo $LD_LIBRARY_PATH就打印出来。
2、配置环境变量的方法简单点就是:
LD_LIBRARY_PATH=LD_LIBRARY_PATH:"/root/nana/so"
export LD_LIBRARY_PATH
3、好了,再次执行ldd就有新发现了。

4、执行./***, OK,输出正常。

 

*******************************************

 

 

——————————————————————————————————————————————————

关于makefile的嵌套调用

1、首先进入一个文件夹,然后在文件夹(比如/so2),在此目录下建一个hello文件夹

       /hello文件夹包含三个文件:hello.h  hello.c   makefile

       hello.h:

      

 

     hello.c

    

     makefile

    

 

好了,此hello文件的文件建好了

【解释】这里主要的一条命令就是gcc -hello.c -fPIC -shared -o libhello.so,然后这里生成的libhello.so并不是在系统 /lib目录下的,所以将.so文件移动到系统/lib里去

=====================================

 

 

2、然后返回/so2文件里,这里面有4个文件 已经建好了的hello文件夹 、test.h   test.c  makefile

     test.h

    

    test.c

   

   makefile

  

 

 好了,makefile完成了

【解释】注意这里的makefile,既make此目录下的,还要进去子目录hello里去make,所以首先进去子目录cd ./hello;make,然后要连接libhello.so,主要是

                gcc test.c -L/lib -lhello -o test,记得要清除.o 和.so文件

=====================================

 

 

———————————————————————————————————————

   

 

 

 总结:学习makefile,它很灵活,要想真正学习它,一本厚厚的书足够你去啃,所以,在学习makefile主要目的是为了我们编译的简单,在期间的问题很多,最糟糕的是忘了了以前看的makefile,所以现在又得从新开始看,反映出两个问题,一是自己开始还没完全吃透,二是自己学习太慢了,时间花的太长,所以以后要改正!然后最简单的现在看只是不是那么吃力了,所以很容易入手,接着就是makefile的嵌套,其实现在想想也不难,关键就是打开文件make一下就行了,最后得把中间文件.o和.so文件清除掉就可以了。碰到的问题再就是语法有的还不知道,所以借鉴也很重要咯。

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值