Linux动态库的制作

ops/2024/10/20 5:22:52/
Linux操作系统支持的函数库分为:
静态库,libxxx.a,在编译时就将库编译进可执行程序中。
优点:程序的运行环境中不需要外部的函数库。
缺点:可执行程序大
动态库,又称共享库,libxxx.so,在运行时将库加载到可执行程序中。
优点:可执行程序小。

Linux动态库的制作

1.生成目标文件:gcc -c -o sub.o sub.c

2.动态函数库创建命令gcc -shared -fpic -o libsub.so sub.o

‐fpic :产生位置无关代码。
‐shared :生成共享库。
用上述命令生成 libsub.so 动态函数库。
此时还不能立即 ./out ,因为在动态函数库使用时,会查找 /usr/lib /lib 目录下的动态函数库,而此时我们生成的库不在里边。

main.c和sub.c的文件内容可以参考上发表的上一个文章 Linux静态库的制作

先删除目标文件:lpych@lpych-virtual-machine:~$ rm sub.o

在创建目标文件:lpych@lpych-virtual-machine:~$ gcc -c -o sub.o sub.c

然后

 第一种方法

 第二种方法(环境变量方法)

第三种方法(需要管理员权限。先sudo vi /etc/ld.so.conf 然后输入密码,在文本里面添加需要执行的main.c所在的目录 /home/lpych

然后再用管理员权限运行一遍 ldconfig /etc/ld.so.conf即可

 

 


http://www.ppmy.cn/ops/56063.html

相关文章

STL——list模拟实现

一、模拟实现源码 #pragma oncenamespace sjx {template <typename T>struct __list_node{__list_node<T>* _next;__list_node<T>* _prev;T _data;__list_node(const T& val T()) :_data(val), _next(nullptr), _prev(nullptr){}};template <typena…

linux下删除当前路径下的所有文件夹但保留文件

打开终端&#xff0c;输入&#xff0c; find . -mindepth 1 -maxdepth 1 -type d -exec rm -r {} 解释&#xff1a; find是查找文件和文件夹的命令。.表示当前路径。-mindepth 1表示最小搜索深度为1&#xff0c;这样不会包括当前目录。-maxdepth 1表示最大搜索深度为1&#x…

算法整理——【贪心算法练习(2)】

我们继续对贪心算法进行练习&#xff0c;积累题目经验。 一、根据身高重建队列 题目为406. 根据身高重建队列 - 力扣&#xff08;LeetCode&#xff09;&#xff0c;假设有打乱顺序的一群人站成一个队列&#xff0c;数组 people 表示队列中一些人的属性&#xff08;不一定按顺…

git上传文件

git init git add . git commit -m " " git remote add origin 仓库的地址 git push -u origin master 如果出现以下问题 可以用这一句强制上传 git push -f origin master

golang 模板引擎常用语法

golang 模板常用语法 1、变量赋值 Action里可以初始化一个变量来捕获管道的执行结果。初始化语法如下&#xff1a; 其中$variable是变量的名字。声明变量的action不会产生任何输出。 {{$variable : pipeline}}福利彩蛋&#xff1a;没有好玩的 API 接口&#xff1f;上百款免费接…

字节码编程javassist之打印方法耗时和入参

写在前面 本文看下如何实现打印方法耗时和入参。 1&#xff1a;程序 需要增强的类&#xff1a; public class ApiTest1 {public Integer strToInt(String str01, String str02) {return Integer.parseInt(str01);}}插桩类 package com.dahuyou.javassist.huohuo.aa;import…

LeetCode377. 组合总和 Ⅳ

为何先遍历背包、后遍历物品&#xff0c;得到的是排列数呢&#xff1f; 以本题为例&#xff1a;&#xff08;背包容量用j表示&#xff0c;选择的物品下标用i表示&#xff09; j为1时&#xff1a; i0&#xff0c;表示把nums[0]放置在该集合的最后一个元素的位置 那么所得集合为…

2024年最适合高级网工的11款Linux

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 你们好&#xff0c;我的网工朋友。 Linux作为一个免费且开源的操作系统&#xff0c;随着时间的推移催生了多个发行版&#xff0c;并且得到了庞大…