原创
如何让程序调至某个地址执行——解析typedef void (*newtypename) (void
2011-2-21 18:06
2781
3
3
分类:
软件与OS
今天读源码,里面有这么一句:typedef void(*ISR_func_t)(void);
比较令人费解。
查资料得:
这是定义了一个新类型ISR_func_t ,它是指向函数的指针,这个函数的参数是void,返回值也是void。
可以这样用:
ISR_func_t somevar ;
这样就定义了一个 ISR_tunc_t 类型的变量,名为somevar。
------举例------
#include <iostream>
using namespace std;
typedef void (*t)();
void fun()
{
cout << "just a test" << endl;
}
int main()
{
t pfun = fun;
pfun();
return 0;
}
----------------
typedef void (*t)() ; 定义一个类型别名
是用*t 取代void ,是用 t 代表 void (*)();
比如 t x;
就是 void (*x)(); //这是一个函数指针 !
------------------
定义t是一种类型,这种类型是一个指针,这个指针指向一个返回值为void的函数。
还有更强的呢,看下面的声明:
int * const * (*hahaha)();
这里定义了一个指向函数的指针hahaha,
函数的返回类型是一个指针,它指向一个常指针类型,这个常指针指向一个整数。
下面是引申~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
要对绝对地址0x100000赋值,我们可以用
- (unsigned int*)0x100000 = 1234;
复制代码那么要是想让程序跳转到绝对地址是0x100000去执行,应该怎么做?
或者,
- typedef void (*func_t)(void);
- func_t ptr;
- ptr = (func_t)addr;
- (*ptr)();
复制代码 | 上面的就是缓冲区溢出攻击的方法 |
|
文章评论(0条评论)
登录后参与讨论