- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有绕路的问题。众所周知,弯路只能在 5 个字节的空间(即“jmp”调用和 4 个字节的地址)之间移动。因此,在类(一种方法)中不可能有“钩子(Hook)”函数,您不能提供“this”指针,因为空间不足(here's 问题得到了更彻底的解释)。所以我整天都在集思广益寻找解决方案,现在我想听听您对这个主题的想法,这样我就不会在不知道是否可行的情况下开始一个 3-5 天的项目。
我最初有 3 个目标,我希望“钩子(Hook)”函数成为类方法,我希望整个方法都是面向对象的(没有静态函数或全局对象),最糟糕/最难的部分是完全动态的。这是我的(理论上)解决方案;使用汇编可以在运行时修改函数(一个完美的例子是任何迂回方法)。那么既然我可以动态修改函数,难道我不应该也能够动态创建它们吗?例如;我分配内存,比方说 ~30 字节(通过 malloc/new)。是否可以将所有字节替换为对应于不同汇编运算符的二进制数(例如 0xE9 是 'jmp'),然后直接调用该地址(因为它包含一个函数)?
注意:我事先知道返回值,以及我想绕道而行的所有函数的所有参数,并且由于我使用的是 GCC,thiscall 约定实际上与 _cdecl 相同。
所以这是我的想法/即将实现;我创建了一个“函数”类。此构造函数采用可变数量的参数(第一个参数除外,它描述了目标函数的返回值)。
每个参数都是对钩子(Hook)将接收的参数的描述(大小,以及它是否是指针)。假设我想为 int * RandomClass::IntCheckNum(short arg1);
创建一个函数类。然后我只需要这样做:Function func(Type(4, true), Type(4, true), Type(2, false));
。其中“类型”定义为 Type(uint size, bool pointer)
。然后通过汇编我可以动态创建函数(注意:这将全部使用 _cdecl 调用约定)因为我可以计算参数的数量和总大小。
编辑:在这个例子中,Type(4, true)
是返回值 (int*),scondType(4, true)
是 RandomClass ' this' 指针和 Type(2, false)
描述了第一个参数(短 arg1)。
有了这个实现,我可以很容易地将类方法作为回调,但它需要大量的汇编代码(我什至没有特别经验)。最后,唯一非动态的是我的回调类中的方法(这也需要前后回调)。
所以我想知道;这可能吗?这需要多少工作量,我是不是太过头了?
编辑:很抱歉,如果我介绍的所有内容都有些模糊,但如果您想要更彻底地解释某些内容,请提出!
EDIT2:我还想知道,是否可以在某处找到所有汇编运算符的十六进制值?一份 list 会有很大帮助!和/或是否有可能以某种方式“保存” asm("");内存地址处的代码(我非常怀疑)。
最佳答案
您所描述的通常称为“thunking”,并且很常见。从历史上看,最常见的目的是在 16 位和 32 位代码之间进行映射(通过自动生成调用现有 16 位函数的新 32 位函数,反之亦然)。我相信一些 C++ 编译器也会生成类似的函数来将基类指针调整为多重继承中的子类指针。
对于您的问题,这似乎是一个可行的解决方案,而且我预计不会出现任何大问题。只需确保使用操作系统所需的任何标志分配内存,以确保内存是可执行的(大多数现代操作系统默认提供不可执行的内存)。
您可能会发现此链接很有帮助,尤其是在 Win32 中工作时:http://www.codeproject.com/Articles/16785/Thunking-in-Win32-Simplifying-Callbacks-to-Non-sta
关于查找汇编操作的十六进制值,我知道的最好的引用是 NASM 汇编器手册的附录(我不只是说那是因为我帮助编写了它)。这里有一份拷贝:http://www.posix.nl/linuxassembly/nasmdochtml/nasmdoca.html
关于C++ 和全动态函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10451635/
Apache服务器全局配置之服务器标识配置篇 服务器标识相关指令: ServerName ServerAdmin ServerSignature ServerTokens UseCanonical
//校验是否全由数字组成 ? 1
具体内容如下: 1 os.system 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc.conf') min=disab
基本操作 查看数据库 ? 1
Xcode使用教程详细讲解是本文要介绍的内容,Xcode是一个款强大的IDE开发环境,就像你在写Windows程序时需要VS2005一样 需要要Xcode为你写Mac程序提供环境。因此,如果你要成为
就如今天遇到随即函数rand();脑海中想到用它做点啥好呢,最后想起了验证码,数字验证码,字母验证码,中文验证码,可是自己不会呀,咋办呢,上网搜,看别人的代码,开不懂,看视频,听老师讲,将其中所遇到
pcre-7.8.tar.gz 正则表达式下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
IDEA常用设置(提高开发效率) 本人也是IDEA编译器的忠实用户了,但是有时出于各种原因,比如更换设备等等,IDEA总是需要重新安装配置。这就让我比较苦恼,因为总是记不全自己之前都修改了
? 1 2
1、 操作环境搭建 系统:Windows7 旗舰版 64位 PHP环境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 去年关闭。 Improve th
我已经为我在 Adobe Fireworks Cs5 中构建的页面生成了 css,我想知道如何为我的标题和其他 div 设置完整宽度。我将显示标题部分的 css 代码。 @charset "utf
您好,我希望表单宽度为 100%。我希望文本框几乎延伸整个页面的宽度,并在文本框的右侧直接放置小的“GO”按钮,所有按钮都在同一行(或 block )上。 现在我的文本框只有其中文本的宽度(“在此处输
我没有设法将全宽页脚粘贴到网页底部。当页脚上方的主要内容低于一定高度时,页脚下方有一个空白区域。我尝试使用各种解决方案,例如以下 css 代码: html,body { margin:0; padd
我想要一个全宽的表格。当我给 position:fixed; 它变成全宽但可滚动不起作用。 简而言之,我需要一个与浏览器主体没有任何边距的表格。 body { font-family: "Helv
我注意到很多大型网站(如 Google 和 Facebook)在查看页面源代码时 99% 的源代码都是 JavaScript。 有人知道这种方法相对于常规 HTML+JavaScript 页面的优势吗
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this q
由于某种原因,我网站上的图片不再是全宽的。 据我所见,所有内容都设置为 100% 宽度。 http://cargocollective.com/btatest 我是不是什么地方都没有? 最佳答案 我认
我正在创建一个菜单并尝试使用 CSS 制作全宽菜单。但是,我不确定菜单项将如何出现在菜单中。 这是问题的截图: 问题出在我得到的“GAP”中。 如果我有固定数量的元素,我知道我可以使用这个逻辑: ul
这个问题在这里已经有了答案: Puzzle: Find largest rectangle (maximal rectangle problem) (6 个答案) 关闭 9 年前。 给定一个二元矩阵
我是一名优秀的程序员,十分优秀!