静态库
在linux环境中, 使用ar命令创建静态库文件.如下是命令的选项:
d -----从指定的静态库文件中删除文件
m -----把文件移动到指定的静态库文件中
p -----把静态库文件中指定的文件输出到标准输出
q -----快速地把文件追加到静态库文件中
r -----把文件插入到静态库文件中
t -----显示静态库文件中文件的列表
x -----从静态库文件中提取文件
还有多个修饰符修改以上基本选项,详细请man ar 以下列出三个:
a -----把新的目标文件(*.o)添加到静态库文件中现有文件之后
b -----***************************************之前
v -----使用详细模式
ar 命令的命令行格式如下: ar [-]{dmpqrtx}[abcfilNoPsSuvV] [membername] [count] archive files... eg: ar -crs hello.a hello.c
动态库
1.创建共享库
gcc -c error.c
gcc -c errorlog.c
gcc -shared -o libapue.so error.o errorlog.o
这样就创建了共享库!
2.编译共享库
假设共享库位于当前目录(即跟程序文件相同的目录中)
gcc -o test -L. -lapue test.c
这样就编译出了不包含函数代码可执行文件了,但是但你运行时会发现linux动态加载器打不到libapue.so文件.
可以用ldd 命令查看可执行文件依赖什么共享库:
ldd test
如何才能让动态加载器发现库文件呢?有两种方法可以解决:
1.环境变量
export LD_LIBRARY_PATH="dir$LD_LIBRARY_PATH"
2.修改/etc/ld.so.conf文件.位于/etc/ld.so.conf
一般应用程序的库文件不与系统库文件放在同一个目录下,一般把应用程序的共享库文件放在/usr/local/lib下,新建一个属于自己的目录apue,然后把刚才libapue.so复制过去就行了
同时在/etc/ld.so.conf中新增一行:
/usr/local/lib/apue
实例分析:
test.c
#include "print.h"
int main(void){
printf("Function : main/n");
print();
printf("out main/n");
return 0;
}
print.c
int print(void){
printf("Function : print/n");
printf("Hello world/n");
printf("out print/n");
return 0;
}
1 : 创建动态库:
gcc -o libprint.so -fPIC -rdynamic -shared print.c
2 : 创建可执行文件
gcc -o test -I$(INC_PATH) -L$(LIB_PATH) -lprint test.c
3 : 如果出现下列错误
./test: error while loading shared libraries: libprint.so: cannot open shared object file: No such file or directory
解决方法:
1:export LD_LIBRARY_PATH=DIR:$LD_LIBRARY_PATH
2:修改文件/etc/ld.so.config文件,在末行加上你的库文件目录,最后,ldconfig刷新ld.so.cache文件即可。可以用strings命令查看ld.so.cache是否刷新:strings /etc/ld.so.cache | grep print
4: ldd命令查看动态连接库
linux-gate.so.1 => (0xb7f0e000)
libprint.so => not found
libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0xb7d82000)
/lib/ld-linux.so.2 (0xb7ef4000)
在linux环境中, 使用ar命令创建静态库文件.如下是命令的选项:
d -----从指定的静态库文件中删除文件
m -----把文件移动到指定的静态库文件中
p -----把静态库文件中指定的文件输出到标准输出
q -----快速地把文件追加到静态库文件中
r -----把文件插入到静态库文件中
t -----显示静态库文件中文件的列表
x -----从静态库文件中提取文件
还有多个修饰符修改以上基本选项,详细请man ar 以下列出三个:
a -----把新的目标文件(*.o)添加到静态库文件中现有文件之后
b -----***************************************之前
v -----使用详细模式
ar 命令的命令行格式如下: ar [-]{dmpqrtx}[abcfilNoPsSuvV] [membername] [count] archive files... eg: ar -crs hello.a hello.c
动态库
1.创建共享库
gcc -c error.c
gcc -c errorlog.c
gcc -shared -o libapue.so error.o errorlog.o
这样就创建了共享库!
2.编译共享库
假设共享库位于当前目录(即跟程序文件相同的目录中)
gcc -o test -L. -lapue test.c
这样就编译出了不包含函数代码可执行文件了,但是但你运行时会发现linux动态加载器打不到libapue.so文件.
可以用ldd 命令查看可执行文件依赖什么共享库:
ldd test
如何才能让动态加载器发现库文件呢?有两种方法可以解决:
1.环境变量
export LD_LIBRARY_PATH="dir$LD_LIBRARY_PATH"
2.修改/etc/ld.so.conf文件.位于/etc/ld.so.conf
一般应用程序的库文件不与系统库文件放在同一个目录下,一般把应用程序的共享库文件放在/usr/local/lib下,新建一个属于自己的目录apue,然后把刚才libapue.so复制过去就行了
同时在/etc/ld.so.conf中新增一行:
/usr/local/lib/apue
实例分析:
test.c
#include "print.h"
int main(void){
printf("Function : main/n");
print();
printf("out main/n");
return 0;
}
print.c
int print(void){
printf("Function : print/n");
printf("Hello world/n");
printf("out print/n");
return 0;
}
1 : 创建动态库:
gcc -o libprint.so -fPIC -rdynamic -shared print.c
2 : 创建可执行文件
gcc -o test -I$(INC_PATH) -L$(LIB_PATH) -lprint test.c
3 : 如果出现下列错误
./test: error while loading shared libraries: libprint.so: cannot open shared object file: No such file or directory
解决方法:
1:export LD_LIBRARY_PATH=DIR:$LD_LIBRARY_PATH
2:修改文件/etc/ld.so.config文件,在末行加上你的库文件目录,最后,ldconfig刷新ld.so.cache文件即可。可以用strings命令查看ld.so.cache是否刷新:strings /etc/ld.so.cache | grep print
4: ldd命令查看动态连接库
linux-gate.so.1 => (0xb7f0e000)
libprint.so => not found
libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0xb7d82000)
/lib/ld-linux.so.2 (0xb7ef4000)