原创 如何让程序调至某个地址执行——解析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赋值,我们可以用
  1. (unsigned int*)0x100000 = 1234;
复制代码

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

或者,
  1. typedef void (*func_t)(void);
  2. func_t ptr;
  3. ptr = (func_t)addr;
  4. (*ptr)();
复制代码
上面的就是缓冲区溢出攻击的方法

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
3
关闭 站长推荐上一条 /3 下一条