您的位置: 首页 计算机类> 等级考试> 二级考试> C++> 辅导资料
公务员考试辅导课程

c/c++语言实现堆栈修改,通过ret跳转到自定义函数

发布时间:09-12

页 数:1页

上一篇:在GraphEdit中显示应用程序的Filtergraph的方法

下一篇:制作主窗口显示前的版权窗口


好处是,编译后没有jmp指令,通过ret 跳转到需要的代码,另外在调试时,某些代码会被当作数据,可以增加调试难度.  缺点,需要调用函数的堆栈有至少4个字节的空间,否则堆栈返回出错.  但是这四个字节空间不会被摧毁.  可能我有些东西还没有照顾到,如果有错误,大家告诉我;) 

编译环境: vc6 vc7 
#include <stdio.h> 

int  somefunc( void *ptr) 
...{ 
    printf("in somefunc... "); 
    return 0; 


void stackbuild( void *ptr) 
...{ 
    printf("in stackbuild... "); 
    *(unsigned int*)(&ptr-1) ^= *(unsigned int*) &ptr; 
    *(unsigned int*)&ptr ^= *(unsigned int*) (&ptr-1);  //注意此处对堆栈操作 
    *(unsigned int*)(&ptr-1) ^= *(unsigned int*) &ptr; 


int main(int argc, char *argv[]) 
...{ 
    // 还是嵌入了一句汇编,平衡堆栈;)哪位高人改改,看能不能把嵌入汇编去掉 
    __asm...{push 0} //预留4字节空间,平衡堆栈,注意此句和下面的句子要一起用,没有下面的调用,必须没有该语句 
    stackbuild(somefunc); 

    printf("exit main... "); 
    return 0; 
}





     

考试信息

热点排行

最近更新

考试辅导

网校辅导

面授培训

©2006-2008 100ksw.com 版权所有 皖ICP备06013378号