老生常谈C语言动态函数库的制作和使用(推荐)

>>>>>>老生常谈C语言接静态函数库的制作和使用>>点击进入

2 动态函数库的制作和使用

动态函数库的制作步骤可以用下图来描述,具体包括

(1) 编写函数的.c文件(例如add.c、sub.c、mul.c和div.c)

(2) 编写Makefile,然后make,实现函数的编译和归档入库

函数的编译:使用gcc –c add.c -fPIC只编译不链接函数.c文件,分别生成函数的目标文件(例如add.o、sub.o、mul.o和div.o)。

函数的归档入库:使用gcc -o libdynamic.so $(objects) -share将目标文件归档入库。

(3) 编写头文件(例如kud.h),声明函数库中所有函数,目的是kudmain.c函数#include头文件后,可以调用相应的函数,至此,完成函数库的制作

2.1 动态函数库的制作示例

示例的内容建立动态函数库libdynamic.so,库中包括add、sub、mul和div函数,然后在kudmain.c函数中引用这4个函数,实现两个整数的加减乘除,整个文件的结构是

(1) 编写函数的.c文件

采用制作静态函数库时的4个函数文件add.c、sub.c、mul.c和div.c,不做任何改动。

(2) 编写头文件

将制作静态函数库时的头文件名ku.h改为kud.h,其他内容不做任何改动。

(3) 编写Makefile

由于制作动态库的命令和制作静态库的命令存在差异,因此需要修改Makefile。

objects = add.o sub.o mul.o div.o

libdynamic.so : $(objects)
  gcc -o libdynamic.so $(objects) -shared

add.o : add.c
  gcc -c add.c -fPIC

sub.o : sub.c
  gcc -c sub.c -fPIC

mul.o : mul.c
  gcc -c mul.c -fPIC

div.o : div.c
  gcc -c div.c -fPIC

clean :
  rm libdynamic.so $(objects)

(4) 使用make编译.c文件,生成.o文件,归档.o文件到函数库libdynamic.so中,完成动态函数库的制作。

2.2 动态函数库的使用

(1)编写kudmain.c,调用libdynamic.so中的add、sub、mul和div函数

#include <stdio.h>
#include "kud.h" 

int main (void)
{
int a,b;
a = 10;
b = 3;
printf("a = %d.\nb = %d.\n",a,b);
printf("static a+b = %f.\n",add(a,b));
printf("static a-b = %f.\n",sub(a,b));
printf("static a*b = %f.\n",mul(a,b));
printf("static a/b = %f.\n",div(a,b));
return 0;
}

(2) 使用gcc kudmain.c –o kudmain.o –L ./ku2 –ldynamic 编译kudmain.c文件,运行./kudmain.o查看运行结果,结果出现ERROR,原因是程序运行load动态函数库时,找不到该函数库。

(3) 解决方法

方法1:将libdynamic.so放到/usr/lib目录下,执行cp kud2/libdynamic.so /usr/lib,然后运行./kudmain.o,程序运行正常,问题得到解决。

方法2:使用环境变量LD_LIBRARY_PATH,程序运行load动态函数库时,会先在LD_LIBRARY_PATH指定的目录下查找函数库,找不到就再去/usr/lib下查找,执行export LD_LIBRARY_PATH=/mnt/hgfs/winshare/kud/kud2:$LD_LIBRARY_PATH,然后运行./kudmain.o,程序运行正常,问题得到解决。

2.3 使用ldd命令查看依赖关系

ldd命令是一个shell脚本,不是一个可执行程序,用于查看某个可执行程序含有什么动态函数库,也即该程序执行时依赖于哪些动态函数库。

$ldd kudmain.o //可见kudmain.o依赖于libdynamic.so

以上这篇老生常谈C语言动态函数库的制作和使用(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • C语言 动态内存分配的详解及实例

    1. 动态内存分配的意义 (1)C 语言中的一切操作都是基于内存的. (2)变量和数组都是内存的别名. ①内存分配由编译器在编译期间决定 ②定义数组的时候必须指定数组长度 ③数组长度是在编译期就必须确定的 (3)但是程序运行的过程中,可能需要使用一些额外的内存空间 2. malloc 和 free 函数 (1)malloc 和 free 用于执行动态内存分配的释放 (2)malloc 所分配的是一块连续的内存 (3)malloc 以字节为单位,并且返回值不带任何的类型信息:void* mallo

  • C语言创建链表错误之通过指针参数申请动态内存实例分析

    本文实例讲述了C语言创建链表中经典错误的通过指针参数申请动态内存,分享给大家供大家参考之用.具体实例如下: #include <stdio.h> #include <stdlib.h>// 用malloc要包含这个头文件 typedef struct node { int data; struct node* next;// 这个地方注意结构体变量的定义规则 } Node; void createLinklist(Node* pHder, int length) { int i =

  • C语言实现支持动态拓展和销毁的线程池

    本文实例介绍了C 语言实现线程池,支持动态拓展和销毁,分享给大家供大家参考,具体内容如下 实现功能 1.初始化指定个数的线程 2.使用链表来管理任务队列 3.支持拓展动态线程 4.如果闲置线程过多,动态销毁部分线程 #include <stdio.h> #include <pthread.h> #include <stdlib.h> #include <signal.h> /*线程的任务队列由,函数和参数组成,任务由链表来进行管理*/ typedef str

  • c语言动态数组示例

    复制代码 代码如下: #include <stdio.h>#include <stdlib.h> int main(){    //从控制台获取初始数组大小    int N;    printf("Input array length:");    scanf("%d",&N);    printf("\n"); //分配空间    int *a;    a=(int *)calloc(N,sizeof(int)

  • C语言构建动态数组完整实例

    本文以一个完整的实例代码简述了C语言构建动态数组的方法,供大家参考,完整实例如下: #include <stdio.h> #include <malloc.h> int main(void) { int len; int * arr; printf("请输入数组长度:"); scanf("%d", &len); arr = (int *)malloc(sizeof(int)*len); printf("请输入数组的值:&qu

  • C语言完美实现动态数组代码分享

    我们知道,C语言中的数组大小是固定的,定义的时候必须要给一个常量值,不能是变量. 这带来了很大的不便,如果数组过小,不能容下所有数组,如果过大,浪费资源. 请实现一个简单的动态数组,能够随时改变大小,不会溢出,也不会浪费内存空间. 下面的代码实现了简单的动态数组: #include <stdio.h> #include <stdlib.h> int main() { //从控制台获取初始数组大小 int N; int *a; int i; printf("Input ar

  • 在C语言中调用C++做的动态链接库

    今天在做东西的时候遇到一个问题,就是如何在C语言中调用C++做的动态链接库so文件 如果你有一个c++做的动态链接库.so文件,而你只有一些相关类的声明, 那么你如何用c调用呢,别着急,本文通过一个小小的例子,让你能够很爽的搞定. 链接库头文件: head.h class A { public: A(); virtual ~A(); int gt(); int pt(); private: int s; }; firstso.cpp #include <iostream> #include &

  • C语言使用DP动态规划思想解最大K乘积与乘积最大问题

    最大K乘积问题 设I是一个n位十进制整数.如果将I划分为k段,则可得到k个整数.这k个整数的乘积称为I的一个k乘积.试设计一个算法,对于给定的I和k,求出I的最大k乘积. 编程任务: 对于给定的I 和k,编程计算I 的最大k 乘积. 需求输入: 输入的第1 行中有2个正整数n和k.正整数n是序列的长度:正整数k是分割的段数.接下来的一行中是一个n位十进制整数.(n<=10) 需求输出: 计算出的最大k乘积. 解题思路:DP 设w(h,k) 表示: 从第1位到第K位所组成的十进制数,设m(i,j)

  • C语言静态链表和动态链表

    1. 静态链表 结构体中的成员可以是各种类型的指针变量,当一个结构体中有一个或多个成员的基类型是本结构体类型时,则称这种结构体为"引用自身的结构体".如: struct link { char ch; struct link *p; } a; p是一个可以指向 struct link 类型变量的指针成员.因此,a.p = &a 是合法的表达式,由此构成的存储结构如图1所示. 图1 引用自身的结构体 例1 一个简单的链表 #include <stdio.h> stru

  • 使用C语言实现vector动态数组的实例分享

    下面是做项目时实现的一个动态数组,先后加入了好几个之后的项目,下面晒下代码. 头文件: # ifndef __CVECTOR_H__ # define __CVECTOR_H__ # define MIN_LEN 256 # define CVEFAILED -1 # define CVESUCCESS 0 # define CVEPUSHBACK 1 # define CVEPOPBACK 2 # define CVEINSERT 3 # define CVERM 4 # define EXP

随机推荐