linux读取dll文件内容,详解dll动态库的开发与调用及文件的读写小程序

详解dll动态库的开发与调用及文件的读写小程序

首先我们先来学习一下动态库的调用,先找到动态库的.dll和.lib文件并将其导入到同源文件相同级别的文件夹下面,然后在添加进其头文件,并右击项目处,然后点击链接,链接我们的lib文件(一定要是全名称包括扩展名),然后我们就可以调用动态库的函数了。

Dll是我们具体的函数, lib使我们的函数描述文件。

#include

#include

/*

该代码是对文件读写操作的使用

*/

#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;

}

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值