详解dll动态库的开发与调用及文件的读写小程序
详解dll动态库的开发与调用及文件的读写小程序
首先我们先来学习一下动态库的调用,先找到动态库的.dll和.lib文件并将其导入到同源文件相同级别的文件夹下面,然后在添加进其头文件,并右击项目处,然后点击链接,链接我们的lib文件(一定要是全名称包括扩展名),然后我们就可以调用动态库的函数了。
Dll是我们具体的函数, lib使我们的函数描述文件。
#include <stdio.h> #include <stdlib.h> /* 该代码是对文件读写操作的使用 */ #pragma warning(disable:4996) #define MAX_DATA_LEN 4096 //进行加密的函数 int FileSymEnc(char * from, char * to); void main() { char * from = "C:/Users/Administrator/Desktop/结构体的拷贝问题.docx"; char * to = "C:/Users/Administrator/Desktop/副本结构体的拷贝问题.docx"; //下面调用函数进行文件的读写 int re = FileSymEnc(from, to); if (re == 0) { printf("文件读写错误!"); } system("pause"); } int FileSymEnc(char * from, char * to) { //返回值,以确定执行状态,-0代表失败,1代表成功 int re = 1; //写了几个 int writtenLen = 0; //准备写几个 int plainlen = 0; //在堆区分配4k内存空间 unsigned char * buff = malloc(MAX_DATA_LEN); buff = memset(buff, 0, MAX_DATA_LEN); FILE * f = fopen(from, "rb"); FILE * t = fopen(to, "wb"); if (f == NULL) { printf("打开读文件错误!"); goto END; } if (t == NULL) { printf("打开写文件错误!"); goto END; } while (!feof(f)) { writtenLen = fread(buff, 1, MAX_DATA_LEN, f); //判读是否读到了文件末尾,如果读到了则跳出循环 if (feof(f)) { plainlen = writtenLen; break; } if (writtenLen != MAX_DATA_LEN) { //没有读取成功 printf("文件读入失败!"); re = 0; goto END; } //读取成功进行文件的写入 writtenLen = fwrite(buff, 1, MAX_DATA_LEN, t); if (writtenLen != MAX_DATA_LEN) { printf("文件写入失败!"); re = 0; goto END; } } //外面处理不到4K的写入问题,我们本不用进行格外的小数据读写,主不过这和我们的加密方式相关连得 writtenLen = fwrite(buff, 1, plainlen, t); if (writtenLen != plainlen) { printf("文件写入失败!"); re = 0; goto END; } END: //堆分配的内存进行释放 if (buff != NULL) { free(buff); buff = NULL; } //进行文件的关闭操作 if (f != NULL) { fclose(f); f = NULL; } if (t != NULL) { fclose(t); f = NULL; } return re; }
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
赞 (0)