本文主要是介绍软硬链接以及动静态库打包、使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
软链接:
上图是我的一个目录下的文件结构,2目录下有一个可执行文件:但是我现在在1目录下(也就是2的上层路径)下,我想执行这个output可执行文件,怎么做?可以用软链接的方式:
[hx@iZ2vcfg8i114ojucj4yd8uZ 1]$ ln -s 2/output link
你可以在1目录下输入上述代码,建立一个链接(link->2/output);此时在1目录下执行link就相当于运送output:
总的目录结构如下:
其实,如果这个output可执行文件在非常深的目录或者干脆就不在2目录下,这个软链接就显示出好处了;
通过ls也可以看出详细链接情况以及它的其他信息:
还有一种情况,我想在当前路径下为这个link创建一个软链接:
我们发现这个软链接linkTolink有自己的inode,它是一个独立的文件;其实类比Windows:(他就像是Windows的桌面快捷方式:双击桌面的快捷方式即可打开某个软件,这个快捷方式本身就是一个文件,在自己的desktop/下存储着,所以它是一个独立的文件;)
使用unlink+软链接名称可以删除;
Linux系统中这样的软链接非常多:
硬链接:
用ln创建而非软链接的ln -s;
硬链接创建的新的文件与原文件用的是同样的inode,他不是独立的文件;
4是硬链接数,表明有几个文件名与某个inode建立了映射,此图中有4个:
不断删除这4个,最后一个文件被你删除后,这个inode将被释放,很想C++的智能指针;(具体是inode结构中有一个count,每创建一个硬链接,count++,每删除一个,count--;当count==0时,释放inode;)
除了使用rm删除也可以使用unlink+名称来删除;
你默认touch一个文件,那个计数是1,即你的这个文件名字和inode是一个映射;
大家看到了,一个目录默认创建出来后,这个计数是2,其实这与 . 和 .. 有关系:
2目录本身与669320建立映射,2目录下的.目录也与669320建立映射,所以2目录的计数是2;
类似地,1目录本身与669319建立映射,2目录下的..669319建立映射,还有1目录下的 . 还要和669319建立映射,所以是3;如下图:
你可以在一个目录下不断建立文件/目录,每个都有一个 .. 与本目录的inode建立链接....
静态库的打包与使用
首先复习一下编译+链接:
第一:g++的-c选项可以编译源文件为.o文件,将.o文件链接即可形成可执行文件(如上图);
第二:有了.h文件和你的.o文件,别人自己实现main.cpp即可使用你的.h文件中声明的函数(首先将你的main.cpp编译为main.o)(按照上述第一条,你只需链接所有的.o文件即可)(不再需要那些.h对应的.cpp源文件,因为具体实现已经编译为.o文件了);
存在问题:如果.o文件比较多,这样就不方便,所以我们需要打包我们的所有.o文件为库文件,再给别人我们的.h文件,别人拿到我们的库+.h文件,写好main.cpp即可使用;
一般打包为库的结构:
如图,hello_static为主目录,下属两个目录,一个装头文件,一个装我们的静态库(.o形成的);
libhello.a是静态库名称,后缀为a,是用ar -rc libhello.a myprint.o mymath.o生成的,你也可以用makefile一键生成:
libhello.a:mymath.o myprint.oar -rc libhello.a mymath.o myprint.o
mymath.o:mymath.cppg++ -c mymath.cpp -o mymath.o
myprint.o:myprint.cppg++ -c myprint.cpp -o myprint.o
.PHONY:clean
clean:rm -rf libhello.a *.o
现在我们已经制作好我们的目录了(名为hello_static),我们试着移动到别处去,自己使用一下:
如上图,目录中只剩下库+.h文件+main.cpp(自己写),然后使用选项来编译(如下图):
注:-I选项是让g++去找头文件,-L是让g++找库,-lhello则是具体的库名称(因为-L路径下有可能有许多库,它不像是头文件已经在main.cpp里包含了,编译器不知道用哪个)(hello是库名称,去掉libhello.a中的lib前缀和.a后缀就是了!)
另外一种方法是:如果这个库你比较常用,你就拷贝至系统路径下(/usr/include(头文件)以及/lib64(库文件)下);
然后直接就可以 :
g++ main.cpp -lhello
一般推荐前者,不用了就直接删掉即可,后者可能时间长了也就忘了哪个是别人的库了....
动态库的打包与使用
动态库的打包与使用我们依然使用刚才的文件,只不过makefile有所区别;
libhello.so:mymath.o myprint.og++ -shared mymath.o myprint.o -o libhello.so
mymath.o:mymath.cppg++ -c -fPIC mymath.cpp -o mymath.o
myprint.o:myprint.cppg++ -c -fPIC myprint.cpp -o myprint.o
.PHONY:clean
clean:rm -rf libhello.so *.o
像刚一样,移动到一个干净的目录里,目录结构如下,写好自己的main.cpp:
要使用动态库,需要用到上文讲到的软链接:
sudo ln -s /home/hx/0420/hello_dynamic/lib/libhello.so /lib64/libhello.so
即在系统库路径下,创建一个软链接指向我的动态库
也就相当于我把动态库拷贝到了系统路径下(快捷方式);执行
g++ main.cpp -I ./include/ -L /lib -lhello
也可以运行成功:
动态库与静态库区别
前者
体积小,即动态库可用节省内存和磁盘空间;
运行时加载至内存,所以比较慢;
多个程序用到了同一个动态库时,地址空间可以都映射这个库,从而不占内存,减少了内存换入换出次数;
后者
体积大,因为静态库会被添加为程序的一部分进行使用;
这篇关于软硬链接以及动静态库打包、使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!