main 并不是程序运行的开始, 如果你愿意, 可以在main之前就运行代码. 下面举个例子做示范
$cat 1_1.c
#include<stdio.h>
void call_1_1()
{
printf("1_1\n");
}
声明 main 运行前后执行的函数, 并且调用 1_1.c 中的函数
$ cat 1.c
#include<stdio.h>
extern void call_1_1();
__attribute__((constructor)) void before_main()
{
printf("before main\n");
call_1_1();
}
__attribute__((destructor)) void after_main()
{
printf("after main\n");
}
用下面这个 Makefile 把 1.c 编译动态链接库 libpnp.so 使用
$ cat Makefile
TARGET=libpnp.so
SRC=1.c
OBJS=$(SRC:.c=.o)
CFLAGS=-ansi -g -Wall -fPIC
CC=gcc
INCLUDE=-l/usr/include/
LINKPARAM=-lpthread -shared -fPIC
all:$(TARGET)
$(TARGET):$(OBJS)
$(CC) -o $(TARGET) $(LINKPARAM) $(OBJS)
.SUFFIXES:.c
.c.o:
$(CC) $(LINKPARAM) $(INCLUDE) $(CFLAGS) -c $<
再构造一个有 main 的文件
$ cat 2.c
int main()
{
printf("in main\n");
return 0;
}
用下面命令最终生成 a.out
gcc -c 1_1.c
gcc 2.c 1_1.o -L. -lpnp
运行得到期望的结果
$ LD_LIBRARY_PATH=. ./a.out
before main
1_1
in main
after main
这个技巧可以用在初始化共享内存中,当你不期望copy 那个代码到 main中, 可以生成一个库, 每次 link 的时候, 自动给你生成想要的代码.