函数原型
int dl_iterate_phdr(
int (*callback) (struct dl_phdr_info *info,
size_t size, void *data),
void *data);
函数作用
允许程序运行时,查询调用的动态库以及调用顺序。该函数遍历共享对象列表,对每次共享对象调用一次回调函数,知道所有的共享对象都遍历完了或者返回一个非零值。
其中,每次调用回调函数包含三个参数:
info, which is a pointer to a structure containing information about the shared object;
size, which is the size of the structure pointed to by info;
and data, which is a copy of whatever value was passed by the calling program as the second argument (also named data) in the call to dl_iterate_phdr().
dl_iterate_phdr 函数的主要作用是提供一种机制,让程序能够动态地获取到系统已经加载的所有共享库的信息。
这些信息包括共享库的加载地址、大小、以及各种节区(segment)的类型等。
通过这个函数,程序可以在运行时进行自我分析或者进行某些操作,比如动态地修改共享库的行为。
举例
下面代码能打印出该段程序运行时用到的动态库:
#define _GNU_SOURCE
#include <link.h>
#include <stdio.h>
int callback(struct dl_phdr_info *info, size_t size, void *data) {
printf("Loaded library: %s\n", info->dlpi_name);
return 0;
}
int main() {
dl_iterate_phdr(callback, NULL);
return 0;
}
编译成可执行文件后,运行输出:
Loaded library:
Loaded library: linux-vdso.so.1
Loaded library: /lib/aarch64-linux-gnu/libc.so.6
Loaded library: /lib/ld-linux-aarch64.so.1
注意:
需要注意的是,dl_iterate_phdr 是一个系统特定的函数,并不是所有的操作系统都提供这个函数。在某些平台上(如 macOS 11.1),这个函数可能是不存在的。因此,在跨平台编程时,需要确认目标平台是否支持这个函数。