linux下 GCC 动态库的链接
1.动态库到编译
hello.c main.c
hello.c
#include <stdio.h>
#include <stdlib.h>
#define NUMBER 100
void PrintHello(void)
{
char ptr[] = "Hello world";
printf("%s\n",ptr);
return;
}
char *GetString(const char *src)
{
char *dest = (char*)malloc(sizeof(NUMBER));
char *temp = dest;
while(*src != '\0')
*dest++ = *src++;
return temp;
}
main.c
#include <stdio.h>
#include "hello.c"
int main(int argc,char **argv)
{
char *string = "this is a test for dll";
PrintHello();
printf("%s\n",GetString(string));
return 0;
}
***************************************
#gcc hello.c -shared -fPIC -o libhello.so
#gcc main.c -L. -lhello -o main
***************************************
#ldd main 会发现无法找到.so 这时候应该把*.so拷贝到使用共享库到路径
#cp libhello.so /usr/lib/
#./main
2.编译参数的解析
3、编译参数解析
最主要的是GCC命令行的一个选项:
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成
弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动
态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
1.动态库到编译
hello.c main.c
hello.c
#include <stdio.h>
#include <stdlib.h>
#define NUMBER 100
void PrintHello(void)
{
char ptr[] = "Hello world";
printf("%s\n",ptr);
return;
}
char *GetString(const char *src)
{
char *dest = (char*)malloc(sizeof(NUMBER));
char *temp = dest;
while(*src != '\0')
*dest++ = *src++;
return temp;
}
main.c
#include <stdio.h>
#include "hello.c"
int main(int argc,char **argv)
{
char *string = "this is a test for dll";
PrintHello();
printf("%s\n",GetString(string));
return 0;
}
***************************************
#gcc hello.c -shared -fPIC -o libhello.so
#gcc main.c -L. -lhello -o main
***************************************
#ldd main 会发现无法找到.so 这时候应该把*.so拷贝到使用共享库到路径
#cp libhello.so /usr/lib/
#./main
2.编译参数的解析
3、编译参数解析
最主要的是GCC命令行的一个选项:
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成
弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动
态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称