/* libname may be a relative path */voID loadlib(char const *libname) { voID *handle = dlopen(libname); /* ... */ dlclose(handle);}
在/ * .. * /中,我需要读取内存映射文件/ proc / self / maps,以查找映射到libname的虚拟内存地址,并且我还需要打开库来查找其中的某些部分.为此,我需要通过在各种地方搜索dlopen找到的绝对名称(例如,在ldconfig缓存文件中).如何收到该文件名?
这是我终于结束了(是的,这是C代码,尽管如此,C标记对于这个问题是有道理的,因为dlopen与C和C一起使用,我的问题符合两者,POSIX指定它为C.).
boost::shared_ptr<voID> dl; if(voID *handle = dlopen(libfile,RTLD_LAZY)) { dl.reset(handle,&dlclose); } else { printdlerr(); return -1; } /* update sofile to be an absolute file name */ { struct link_map *map; dlinfo(dl.get(),RTLD_DI_linkMAP,&map); if(!map) { return -1; } char *real = realpath(map->l_name,NulL); if(!real) return -1; sofile.reset(real,&free); }
libfile是相对/纯文件名.该地图将产生一个非纯文件名(即不是foo.so,但可能是./foo.so).之后,我使用realpath来获取最终的绝对路径名.它工作很好!
解决方法 你可以使用... dlinfo(handle,p)p->l_name ...
其中p是link_map类型**
有关详细信息,请参阅man dlinfo
总结以上是内存溢出为你收集整理的c – 如何获取对应于给予dlopen的相对路径的绝对库文件名?全部内容,希望文章能够帮你解决c – 如何获取对应于给予dlopen的相对路径的绝对库文件名?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)