zoukankan      html  css  js  c++  java
  • 模拟DLL加载

    #include <stdio.h>
    #include <malloc.h>
    #include <sys/stat.h>
    typedef int (*PFUNC)(int,int);
    typedef struct
    {
        int Position;
        int Length;
    }Fun;
    
    typedef struct
    {
        int num;
        Fun *pFun;
    }Lib;
    
    int main()
    {
     
        int FileSize =0;
        char FileName[] = "code.obj";
        FILE * FileHandle = fopen(FileName,"rb");
        if(FileHandle!=NULL)
        {
            Lib lib;
            fread(&lib.num,sizeof(char),4,FileHandle);
            //确定文件中有几个函数
            lib.pFun =(Fun*)malloc(sizeof(Fun)*lib.num);
            fread(lib.pFun,sizeof(Fun),lib.num,FileHandle);
            //读取文件中第一个函数的信息,(在文件中的)地址和长度
            char *instruction= (char*)malloc(sizeof(char)*lib.pFun->Length);
            //根据函数在内存中为函数分配空间
            fseek(FileHandle,lib.pFun->Position,0);
            //移动至函数地址,以字节为单位,0代表文件第一个字节
            fread(instruction,sizeof(char),lib.pFun->Length,FileHandle);
            //读取函数指令到预留内存
            PFUNC pfunc = (PFUNC)instruction;
            printf("%d 
    ",pfunc(3,4));
            //执行函数
        }
    }
    
    /*
    说明:
    1)没有附带函数类型信息,如果支持函数类型信息,那么可以说这就是DLL文件
    2)读取文件时可以把文件想象成一个char A[m],有一个char的指针指向到这个
     数组,并在这个数组中前后移动,初始指到A[0],我们总是从这个指针指向的
     地址向后读取一定的字节复制到另一个数组,假设指针指向A[0],我们要读取
     10个字节,读取完之后,指针定位到A[10],当然,我们也可以借助fseek任意的
     移动指针
    size_t fread(void *buffer,size_t size,size_t count,FILE *stream)
    {
        int i=0;
        while(stream->ptr!=NULL && i<count)
        {
            buffer = stream->ptr;
            (stream->ptr)++;
        }
        return i;
    } // 假想的函数代码 
     
    int fseek( FILE *stream,long offset,int origin)
    {
        stream->ptr = offset + origin
    }
    */

    CODE.OBJ
    01 00 00 00 0C 00 00 00 2B 00 00 00 55 8B EC 81
    EC C0 00 00 00 53 56 57 8D BD 40 FF FF FF B9 30
    00 00 00 B8 CC CC CC CC F3 AB 8B 45 08 03 45 0C
    5F 5E 5B 8B E5 5D C3

  • 相关阅读:
    LINQ学习(1)
    [转]键盘上的标点符号的中英文名称对照表
    微信Android ANR原理解析及解决方案
    IOS错误日志抓取和分析
    蚂蚁金服测开面试题--转账功能
    MySQL CONV()函数
    分页功能
    在alert里面加入一个页面,子页面传值父页面
    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; che
    缘起 网络编程
  • 原文地址:https://www.cnblogs.com/code-style/p/4602899.html
Copyright © 2011-2022 走看看