如何更改应用程序加载基地址

应用程序的基地址默认都是:0x00400000

如果想更改这个基地址,可以更改链接选项,如下:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 平台上,我们可以通过 `dlopen()` 函数动态库,并使用 `dlsym()` 函数获取动态库中的函数地。`dlopen()` 函数可以指定动态库的路径,也可以使用系统默认搜索路径来查找动态库。而 `dlsym()` 函数可以传入动态库句柄和函数名来获取函数地。 当一个应用程序一个动态库时,该动态库的基地将被系统动态分配,因此我们通常无法在应用程序中直接获取动态库的基地。但是,在使用 `dlopen()` 函数动态库时,可以通过设置 `RTLD_NOLOAD` 标志来查询动态库是否已经被,如果已经,则可以使用 `dladdr()` 函数查询动态库的基地。具体代码如下: ```c++ #include <dlfcn.h> #include <cstdio> void* get_module_base(pid_t pid, const char* module_name) { FILE* fp = nullptr; void* addr = nullptr; char* line = nullptr; char* path = nullptr; char filename[32]; char buffer[1024]; if (pid < 0) { snprintf(filename, sizeof(filename), "/proc/self/maps"); } else { snprintf(filename, sizeof(filename), "/proc/%d/maps", pid); } fp = fopen(filename, "r"); if (fp != nullptr) { while (fgets(buffer, sizeof(buffer), fp)) { if (strstr(buffer, module_name)) { line = buffer; break; } } if (line != nullptr) { char* ptr = strtok(line, " "); path = strtok(nullptr, " "); strtok(nullptr, " "); addr = (void*)strtoul(ptr, nullptr, 16); } } if (fp) { fclose(fp); } return addr; } void* get_library_base(const char* library_name) { void* handle = dlopen(library_name, RTLD_LAZY | RTLD_LOCAL | RTLD_NOLOAD); if (handle != nullptr) { Dl_info info; dladdr(handle, &info); dlclose(handle); return info.dli_fbase; } return nullptr; } ``` 其中,`get_module_base()` 函数可以根据进程 ID 和模块名来获取模块的基地。如果进程 ID 为负数,则表示获取当前进程的模块基地。而 `get_library_base()` 函数可以根据库名来获取库的基地。该函数使用 `dlopen()` 函数库,并使用 `dladdr()` 函数查询库的基地。注意,使用 `RTLD_NOLOAD` 标志库时,该库必须已经被其他进程或线程过,否则 `dlopen()` 函数将会失败。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值