gcc生成静态库.a和动态库.so

本文详细介绍了如何在Linux环境中创建静态库和动态库,包括源程序的编写、编译和链接。通过实例展示了静态库与动态库的生成步骤,以及它们在程序中的使用。静态库在编译时被连接,运行时不再需要;动态库则在运行时加载。此外,还讨论了两者之间的区别和如何解决动态库运行时的依赖问题。
摘要由CSDN通过智能技术生成

一、用gcc生成静态库和动态库

(1)前言

本文主要通过举例来说明在linux中如何创建静态库和动态库,以及使用他们。

(2)函数库介绍

函数库分为静态库动态库

  • 静态库
    在程序编译时会被连接到目标代码中,程序运行是则不需要静态库的存在。
  • 动态库
    在程序编译时不会被连接到目标代码中,而是程序运行时载入的。
    两者区别:前者是编译连接的,后者是程序运行载入的。

(3)准备源程序

第一步:编辑生成例子程序hello.h、hello.c、main.c。

先创建一个目录,保存此次所用的文件。

mkdir test1
cd test1

然后用vim、nano、或gedit等文件编辑器生成所需的三个文件。
hello.c是函数库的源程序,其中包含公用函数hello,该函数将在屏幕上输出“Hello wz!”。hello.h为该函数的头文件。main.c为测试库文件的主程序,在主程序中调用了公共函数hello。

程序1:hello.h

#ifndef HELLO_H
#define HELLO_H
void hello(const char *name);
#endif//HELLO_H

程序2:hello.c

#include<stdio.h>
void hello(const char *name)
{
	printf("Hello %s\n",name);
}

程序3:main.c

#include"hello.h"
int main()
{
	hello("everyone");
	return 0;
}
第二步:将hello.c编译成.o文件。

无论静态库还是动态库,都是由.o文件创建的。因此,我们必须将源程序hello.c通过gcc先编译成.o文件。在系统的提示符下键入以下命令得到hello.o文件。

gcc -c hello.c

之后可以用ls命令查看上一条命令是否生成了hello.o文件
在这里插入图片描述

(4)静态库使用

第一步:创建静态库

创建静态库的工具:ar
静态库文件命名规范:以lib作为前缀,是.a文件

ar -crv libmyhello.a hello.o

在这里插入图片描述

第二步:程序中使用静态库
  1. gcc -o hello main.c -L. -lmyhello
    对于自定义的静态库,main.c还可以放在-L.和-lmyhello之间,否则myhello没有定义。
    -L.:表示连接的库在当前目录
    在这里插入图片描述
  2. gcc main.c libmyhello.a -o hello

在这里插入图片描述

  1. 先生成main.o gcc -c main.c
    生成可执行文件 gcc -o hello main.c libmyhello.a
    在这里插入图片描述
第三步:验证静态库的特点

在删掉静态库的情况下,运行可执行文件,发现程序仍旧正常运行,表明静态库跟程序执行没有联系。同时,也表明静态库是在程序编译的时候被连接到代码中的。
在这里插入图片描述

(5)在程序中执行动态库

  1. 创建动态库
    创建动态库的工具:gcc
    动态库文件命名规范:以lib作为前缀,是.so文件
gcc -shared -fPIC -o libmyhello.so hello.o

其中shared:表示指定生成动态链接库,不可省略
-fPIC:表示编译为位置独立的代码,不可省略
在这里插入图片描述

  1. 在程序中执行动态库
gcc -o hello main.c -L. -lmyhello或gcc main.c libmyhello.so -o hello

在这里插入图片描述
此时运行可执行文件hello,会出现错误如上
解决方法:将libmyhello.so复制到目录/usr/lib中。由于运行时,是在/usr/lib中找库文件的。

mv libmyhello.so /usr/lib

在这里插入图片描述

(6)静态库与动态库比较

  • gcc编译得到.o文件 gcc -c hello.c
  • 创建静态库 ar -crv libmyhello.a hello.o
  • 创建动态库 gcc -shared -fPIC -o libmyhello.so hello.o
  • 使用库生成可执行文件 gcc -o hello main.c -L. -lmyhello
  • 执行可执行文件 ./hello
  • 在执行可执行文件,会报一个错误,可见当静态库和动态库同时存在的时候,程序会优先使用动态库。

二、实例1使用库

(1)按照hello.c的方法编写程序

在这里插入图片描述
A1.c

#include<stdio.h>
void print1(int arg)
{
	printf("A1 print arg:%d\n",arg);
}

A2.c

#include<stdio.h>
void print2(char *arg)
{
	printf("A2 printf arg:%s\n",arg);
}

A.h

#ifndef A_H
#define A_H
void print1(int);
void print2(char *);
#endif

test.c

#include<stdio.h>
#include"A.h"
int main()
{
	print1(1);
	print2("test");
	exit(0);
}

2. 程序中使用静态库

ar crv libfile.a A1.o A2.o
gcc -o test test.c libfile.a

3. 动态库的使用

gcc -shared -fPIC -o libfile.so A1.o A2.o
gcc -o test test.c libfile.so

三、实例2使用库

代码
sub1.c

float x2x(int a,int b)
{
	float c=0;
	c=a+b;
	return c;
}

sub2.c

float x2y(int a,int b)
{
	float c=0;
	c=a/b;
	return c;
}

sub.h

#ifndef SUB_H
#define SUB_H
float x2x(int a,int b);
float x2y(int a,int b);
#endif

main.c

#include<stdio.h>
#include"sub.h"
void main()
{
	int a,b;
	printf("Please input the value of a:");
	scanf("%d",&a);
	printf("Please input the value of b:");
	scanf("%d",&b);
	printf("a+b=%.2f\n",x2x(a,b));
	printf("a/b=%.2f\n",x2y(a,b));
}

静态库
ar crv libsub.a sub1.o sub2.o
gcc -o main main.c libsub.a
在这里插入图片描述
gcc -shared -fPIC libsub.so sub1.o sub2.o
gcc -o main main.c libsub.so

静态库与动态库的生成文件的比较
静态库:
在这里插入图片描述
动态库:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值