模拟DLL加载
2015-06-26 17:45
323 查看
#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 \n",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
相关文章推荐
- Android 中的DisplayMetrics类的用法
- 适配器模式
- bootstrap
- Maven : 将Jar安装到本地仓库和Jar上传到私服
- js数组的操作
- Lucene.Net 2.3.1开发介绍 —— 四、搜索(一)
- iOS文件操作
- 认识自己——恐惧的奴隶3:妈妈
- 关于js调用ocx控件报错"对象不支持此属性或方法"的解决方法
- python中的深拷贝和潜拷贝
- Mac OS X (Intel) 上安装 Oracle 10g
- C#多线程与Unity中的使用
- Javascript常用功能
- 合并多个EXCEL工作簿
- [SQL入门级] 第一天 SQL初步
- python读取TXT到数组及列表去重后按原来顺序排序的方法
- IOS学习实例之五---三级控制器
- 对java抽象类的理解
- struts2学习笔记(4)---声明式异常
- 关于CommonJS的几点注解