编译链接小小的总结了一下,有以下4种,各自测试了一个实例,效果不错!
下面仅仅是列出了实例,没有具体阐述其中的含义,有兴趣的可以参考上一篇《深入理解计算机系统》之链接——读书笔记,里面解释了链接的一些基本概念,但是缺乏更深入的理解……
直接上代码——说明一切~
1.静态编译:
<span style="font-size:14px;">/*foo.c*/
#include<stdio.h>
void f(void)
int x =2;
int y =3;
int main()
{
f();
printf("x = 0x%x y = 0x%x \n", x,y);
return0;
}</span>
<span style="font-size:14px;">/*bar.c*/
double x;
void f()
{
x =-0.0;
}</span>
<span style="font-size:14px;">/*bar.c*/
double x;
void f()
{
x =-0.0;
}</span>
$:gcc -o foobar foo.c bar.c
$:./foobar
$:x = 0xx y = 0x80000000
2.与静态库连接
<span style="font-size:14px;">/*addvec.c*/
void addvec(int*x,int*y,int*z,int n )
{
int i;
for(i =0; i < n; i++)
z[i]= x[i]+ y[i];
}
/*multvec.c*/
void multvec(int*x,int*y,int*z,int n)
{
int i;
for(i =0; i < n; i++)
z[i]= x[i]*y[i];
}
/*vector.h*/
void addvec(int*x,int*y,int*z,int n );
void multvec(int*x,int*y,int*z,int n);
/*main2.c*/
#include<stdio.h>
#include"vector.h"
int x[2]={1,2};
int y[2]={3,4};
int z[2];
int main()
{
addvec(x,y,z,2);
printf("z = [%d %d]\n",z[0], z[1]);
return0;
}</span>
$:gcc –c addvec.c multvec.c
$:ar rcs libvector.a addvec.o multvec.o
$:gcc –o2 –c main2.c
$:gcc –static -0 p2 main2.o ./libvector.a
3动态链接共享库
$:gcc -shared -fPIC -o libvector.so addvec.c multvec.c
$:gcc -o p2 main2.c ./libvector.so
$:./p2
4从应用程序中加载和链接共享库
<span style="font-size:14px;">/*dll.c*/
#include<stdio.h>
#include<stdlib.h>
#include<dlfcn.h>
int x[2]={1,2};
int y[2]={3,4};
int z[2];
int main()
{
void*handle;
void(*addvec)(int*,int*,int*,int);
char*error;
handle = dlopen("./libvector.so",RTLD_LAZY);//加载和链接共享库
if(!handle){
fprintf(stderr,"%s\n",dlerror());
exit(1);
}
addvec = dlsym(handle,"addvec");//函数的输入是前面已经打开共享库的句柄和一个符号名字
if((error = dlerror())!= NULL){
fprintf(stderr,"%s\n",error);
exit(1);
}
addvec(x,y,z,2);
printf("z = [%d %d]\n",z[0],z[1]);
if(dlclose(handle <0)){//卸载共享库
fprintf(stderr,"%s\n",dlerror());
exit(1);
}
return0;
}</span>
$:gcc -shared -fPIC -o libvector.so addvec.c multvec.c
$:gcc -rdynamic -o2 -o p3 dll.c -ldl
$:./p3