文章目录
一、写入程序并生成静态库和动态库
1、创建目录
使用命令:mdkir work创建一个工作目录并且使用命令:cd work进入到工作目录目录work下面进行操作
2、编写hello程序并编译得到hello.o文件
使用vim工具生成hello.h、hello.c、main.c三个程序并编入代码
hello.h
#ifndef HELLO_H
#define HELLO_H
void hello(const char *name);
#endif//HELLO_H
hello.c
#include<stdio.h>
void hello(const char *name)
{
printf("Hello %s\n",name);
}
main.c
#include"hello.h"
int main()
{
hello("everyone");
return 0;
}
编译得到hello.o文件并使用ls命令查看已成功生成
3、静态库的使用
创建静态库的工具:ar
静态库文件命名规范:以lib作为前缀,是.a文件
使用命令:gcc -o hello main.c -L. -lmyhello生成静态库并用ls命令查看
再使用命令:gcc -o hello main.c libmyhello.a生成可执行文件,运行成功
另一种方法使用命令:gcc main.c libmyhello.a -o hello运行也是成功的
4、动态库的使用
注:此处是之后在做的,我把之前的文件移入了static文件夹中
创建动态库的工具:gcc
动态库文件命名规范:以lib作为前缀,是.so文件
使用命令:gcc -shared -fPIC -o libmyhello.so hello.o创建动态库
使用命令:gcc -o hello main.c -L. -lmyhello或gcc main.c libmyhello.so -o hello在程序中执行动态库
然后你会发现系统报错找不到文件,总是由于Ubuntu系统在运行时,是在/usr/lib或者/lib中找库文件的,所以会报错
问题的解决方法:将libmyhello.so复制到目录/lib或者/user/lib中。我的属于前者,之后成功编译
并且可见可见当静态库和动态库同时存在的时候,程序会优先使用动态库
二、执行两个库文件并进行比较
1、代码
x2x函数
#include <sub.h>
float x2x(int a,int b)
{
float c=0;
c=a+b;
return c;
}
x2y函数
#include <sub.h>
float x2y(int a,int b)
{
float c;
c=a*b;
return c;
}
头文件代码
#ifndef SUB_H
#define SUB_H
float x2x(int a,int b);
float x2y(int a,int b);
#endif
主函数
#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("axb=%.2f\n",x2y(a,b));
}
2、生成静态库文件
使用命令:ar crv libsub.a sub1.o sub2.o 生成静态库文件
运行静态库文件得到正确的结果
3、生成动态库文件
使用命令:gcc -shared -fPIC -o libsub.so sub1.o sub2.o 生成动态库文件
使用命令:gcc -o main main.c libsub.so 编译运行动态库文件,然后你会发现系统报错找不到文件,总是由于Ubuntu系统在运行时,是在/usr/lib或者/lib中找库文件的,所以会报错
问题的解决方法:将libmyhello.so复制到目录/lib或者/user/lib中。我的属于前者,之后成功编译
静态库与动态库的生成文件的比较
静态库
三、Linux GCC常用命令和GCC编译器的学习
1、Linux GCC常用命令
创建程序文件hello.c并编入代码
编译得到可执行文件并且运行程序
得到正确输出
2、GCC编译器背后的故事
创建代码文件(我使用的是刚刚的hello.c程序文件)
编译得到可执行文件并且运行程序
使用命令:size hello 查看程序大小
3、分析 ELF 文件
ELF 文件的段:
ELF 文件位于 ELF Header 和 Section Header Table 之间。
一个典型的 ELF 文件包含下面几个段:
.text:已编译程序的指令代码段。
.rodata:ro 代表 read only,即只读数据(譬如常数 const)。
.data:已初始化的 C 程序全局变量和静态局部变量。
.bss:未初始化的 C 程序全局变量和静态局部变量。
.debug:调试符号表,调试器用此段的信息帮助调试。
使用命令:readelf -S 查看其各个section的信息
最后使用命令:objdump -S 将其反汇编