库文件可以使用里面的函数,但不能看到那些参数,函数的实现
静态库:
在(编译之前)执行程序之前就已经加入到执行代码中,成为执行程序的一部分来执行的,后缀名:.a
动态库:
是在(执行中)执行程序启动时加载到执行代码中,后缀名:.so
用这2种库生成文件的区别:
可执行文件大(占用内存大):静态库
部署文件容易:静态库
执行效率好:静态库
程序的升级方面更容易:动态库
如何制作动态库、动态库,把gcc当成一个工厂
静态库:gcc -c add.c,变成.o文件 ar rcs libadd.a add.o(lib是前缀,必须是这个,将.o的文件封装在libadd.a里)
cp libadd.a /lib
gcc main.c -ladd(在系统默认的lib库里找)
gcc main.c -ladd -L.(在当前文件里找)
动态库:创建:gcc -shared-fPIC-o 库名.so 源文件.c
使用:gcc 源文件.c./ 库名.so-o 可执行文件名
静态库:
在(编译之前)执行程序之前就已经加入到执行代码中,成为执行程序的一部分来执行的,后缀名:.a
动态库:
是在(执行中)执行程序启动时加载到执行代码中,后缀名:.so
用这2种库生成文件的区别:
可执行文件大(占用内存大):静态库
部署文件容易:静态库
执行效率好:静态库
程序的升级方面更容易:动态库
如何制作动态库、动态库,把gcc当成一个工厂
静态库:gcc -c add.c,变成.o文件 ar rcs libadd.a add.o(lib是前缀,必须是这个,将.o的文件封装在libadd.a里)
cp libadd.a /lib
gcc main.c -ladd(在系统默认的lib库里找)
gcc main.c -ladd -L.(在当前文件里找)
动态库:创建:gcc -shared-fPIC-o 库名.so 源文件.c
使用:gcc 源文件.c./ 库名.so-o 可执行文件名