zoukankan      html  css  js  c++  java
  • 一步一步实现自己的模拟控件(2)——窗口过程thunk

    实现Window Proc Thunk:

    就好像水泵一样,我们的系统也需要一个泵——消息泵,也就是前面图上的Message Driver。这个Driver的可以依靠一个Window Proc Thunk来截获窗口消息,那么我们得先实现一个Window Proc Thunk。

    这里我选择的方法是拿现成的代码来用,微软ATL框架中提供有thunk的实现,我将其提取出来稍加修改就能为我们所用了。

    以下是其实现的一点代码片段:

    void* __stdcall AllocStdCallThunk(void);
    void __stdcall FreeStdCallThunk(void*);

    #pragma pack(push, 1)
    class StdCallThunk_{
    DWORD mov_;
    // mov dword ptr [esp+0x4], this_ (esp+0x4就是第一个参数)
    DWORD this_; //
    BYTE jmp_; // jmp proc
    DWORD relproc_; // relative jmp

    public:
    bool Init(DWORD_PTR proc, void* pThis)
    {
    mov_
    = 0x042444C7; //C7 44 24 0C
    this_ = PtrToUlong(pThis);
    jmp_
    = 0xe9;
    relproc_
    = DWORD((INT_PTR)proc - ((INT_PTR)this+sizeof(StdCallThunk_)));
    // 用自身更新指令缓存
    return ::FlushInstructionCache(::GetCurrentProcess(), this, sizeof(StdCallThunk_)) ? true : false;
    }
    // 某些thunk将动态的为代码分配内存
    void* GetCodeAddress()
    {
    return this;
    }
    void* operator new(size_t)
    {
    return AllocStdCallThunk();
    }
    void operator delete(void* pThunk)
    {
    FreeStdCallThunk(pThunk);
    }
    };
    #pragma pack(pop)

    下载测试工程源码

    By Evil.Ghost
  • 相关阅读:
    Educational Codeforces Round 49 (Rated for Div. 2)
    Codeforces Round #506 (Div. 3)
    multiset
    C++中substr函数的用法
    7.30 背包问题
    7.29 dp动态规划
    7.27 图论 存图 前向星 最短路 dijstra算法 SPFA算法
    7.26 搜索进阶(状压搜索,迭代加深搜索)
    7.23 深搜广搜
    7.24 二分搜索
  • 原文地址:https://www.cnblogs.com/EvilGhost/p/Abstract_Widget_2.html
Copyright © 2011-2022 走看看