900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧

C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧

时间:2018-07-18 14:07:18

相关推荐

C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧

要对绝对地址0x100000赋值,我们可以用

(unsigned int * ) 0x100000 = 1234;

那么要是想让程序跳转到绝对地址是0x100000去执行,应该怎么做?

*((void (*)( ))0x100000 ) ( );

首先要将0x100000强制转换成函数指针,即:

(void (*)())0x100000

然后再调用它:

*((void (*)())0x100000)();

用typedef可以看得更直观些:

typedef void(*)() voidFuncPtr;

*((voidFuncPtr)0x100000)();又如如果用 C 语言,可以像下列示例代码这样来调用内核:void (*theKernel)(int zero, int arch, u32 params_addr)

= (void (*)(int, int, u32))KERNEL_RAM_BASE;

……

theKernel(0, ARCH_NUMBER, (u32) kernel_params_start);

KERNEL_RAM_BASE 是内核在系统内存中的第一条指令的地址。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。