zoukankan      html  css  js  c++  java
  • 巧妙的Section — — 剖析ATL OBJECT_MAP的自动建立

    基本知识

    1、#pragma section,建立一个section。下例中,ATL是section名,_a是section中的的段名,段默认大小为104H,另外默认段内数据初始化为0。意即一个section可以包含多个名字不同的段。不懂section的请查阅PE文件结构。

    2、合并两个Section

    3、allocate将指定的变量放在指定的section中的指定的段中。

    4、VC编译器属性,假设定义了同一section的三个段,ATL$_a、ATL$_b、ATL$_c,则这三个段在section内会按名称顺序依次排列。

    ATL OBJ_MAP 的建立

    根据【基本知识】,很容易分析出,上文定义了一个ATL section,然后在其中定义了三个段,__a、__z、__m。

    为什么要这么做呢?

    ATL将一个指针放在__a段,那么取其地址&__pobjMapEntryFirst表示的就是__a段的起始地址。

    ATL将一人指针放在__z段,那么取其地址&__pobjMapEntryLast表示的就是__z段的起始地址。

    最后,ATL将所有OBJ_MAP_ITEM的数据放在__m段中。

    那么,做了以上这么多事之后呢?我们怎样获取和遍历对象数组?

    其实答案已经出来了,上面分析了,我们有了起始指针__pobjMapEntryFirst,我们有了结尾指针__pobjMapEntryLast,而根据【基本知识】,__m段夹在这两个指针之间,所以我们只要从起始指针遍历到结尾指针就能获取到所有的对象了。

    ok,剖析OVER,最后感叹一下,牛B轰轰的ATL!

  • 相关阅读:
    Chrome扩展开发之一——Chrome扩展的文件结构
    Chrome扩展开发(Gmail附件管理助手)系列之〇——概述
    Springfox与swagger的整合使用
    Maven的简单使用
    关于接口功能自动化的思考
    发版流程优化备忘录
    Aho-Corasick 自动机 学习笔记
    Luogu P1495 曹冲养猪
    Luogu P2670 【扫雷游戏】
    1.1 整除
  • 原文地址:https://www.cnblogs.com/tekkaman/p/2037235.html
Copyright © 2011-2022 走看看