C语言中将绝对地址转换为函数指针以及跳转到内存指定位置处执行的技巧
2015-11-13 22:58
801 查看
要对绝对地址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 是内核在系统内存中的第一条指令的地址。
(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 是内核在系统内存中的第一条指令的地址。
相关文章推荐
- C++虚拟继承与虚基类
- C++虚拟继承与虚基类
- C语言位操作符的使用
- 在图中寻找最短路径-----深度优先算法C++实现
- KMP算法——C++实现版
- 64位Ubuntu无法安装 lib32stdc++6问题
- Strchr()函数详解
- dancing links解决X问题的C++实现
- JAVA C# C/C++之比较学:初始化顺序
- C++模板元编程 - 挖新坑的时候探索到了模板元编程的新玩法
- C++11新特性
- C++学习第二课
- C++常见面试题
- C++ 构造过程和析构过程
- 成员函数后面加const,没有const,以及使用的区别
- C语言字符串操作函数
- C++类的多继承
- C++命名准则
- 关于C++中子类调用父类方法的一个问题
- C++中this指针的用法详解