• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - iPhone上的dyld API - 奇怪的输出

[复制链接]
菜鸟教程小白 发表于 2022-12-11 22:43:21 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我有三个问题要问你,都与 dyld 相关

我一直在使用this dyld man page作为基础。我已经编译了以下代码并在我的越狱设备上成功执行了二进制文件。

#include <stdio.h>
#include <mach-o/dyld.h>

int main(int argc, const char* argv[]) {
   uint32_t image_count, i;
   image_count = _dyld_image_count();
   for (i = 0; i < image_count; i++) {
        printf("%s\n", _dyld_get_image_name(i));
   }
   return 0;
}

我认为这些函数可以让我找到加载到我的程序地址空间中的所有共享库。在我的 Mac 上,输出非常简单:它显示了当前加载到内存中的所有库的路径。在我的 iPhone 上,输出几乎相同——我也获得了文件路径——但指定位置没有文件。 (另一方面,在我的 Mac 上,我可以找到文件!)

这是输出中的示例行: /usr/lib/system/libdyld.dylib

根据 ls、iFile 和我使用的所有其他工具,这个目录 (/usr/lib/system/) 是空的。为什么?这些文件在哪里?

我想知道的另一件事是:是否可以在内存中找到一个库?从什么偏移量到库映射到内存的偏移量?我想我知道如何找到开始,但我不知道如何找到图书馆的尽头。要找到开头,我会使用 _dyld_get_image_header 返回的地址 - 对吗?

最后一个问题:我想在系统范围内加载一个动态库,所以我认为我可以使用 DYLD_INSERT_LIBRARIES 来做到这一点。但是,我在插入 lib 后尝试执行的每个二进制文件都会崩溃并产生总线错误!是我忘记了什么,还是导致崩溃的动态库?



Best Answer-推荐答案


这些库位于: /System/Library/Caches/com.apple.dyld/dyld_shared_cache_armv6 (_armv7) 这是一个大文件,所有单个库都已合并为一个大文件。

http://iphonedevwiki.net/index.php/MobileSubstrate用于连接越狱设备

是的,即使在非越狱设备上,也可以确定 dylib 在内存中的位置。 解析库的 LC_SEGMENT(_TEXT)-Section Header(_text) 就可以得到库的基地址和 TEXT __text 段的大小。然后查询 vmslide。将此添加到 TEXT __text 的基地址。

可以在此处找到有关 mach-o 文件格式的详细说明: https://developer.apple.com/library/mac/#documentation/DeveloperTools/Conceptual/MachORuntime/Reference/reference.html .特别注意“segment_command”-结构。

关于ios - iPhone上的dyld API - 奇怪的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10213990/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap