服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - 详解dll动态库的开发与调用及文件的读写小程序

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

2021-06-03 14:26奋斗的小面包 C/C++

这篇文章主要介绍了详解dll动态库的开发与调用及文件的读写小程序的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#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;
}

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

原文链接:http://blog.csdn.net/c1523456/article/details/76241850

延伸 · 阅读

精彩推荐