详细讲解MySQL数据库对文件操作的封装

作者:10933 时间:2008-12-17 16:08:00 

在查看MySQL对文件的操作中,它在不同的操作系统上对文件的操作,除了使用标准C运行库函数,包括open、close、seek等,在Win32下的文件和目录操作函数使用了CreatFile、CloseHandl、SetFilePointer等,很多人可能不明白为什么对文件的操作要封装出两套函数。

其实使用API和标准库函数都可以生成文本文件和二进制文件,在这点上没有区别。同read()对应的是ReadFile,同write()对应的是WriteFile,同seek()对应的是SetFilePointer,同close对应的是CloseHandle。这两套函数都可以使用。但是Win 32系统把文件的概念进行了扩展。无论是文件、通信设备、命名管道、邮件槽、磁盘、还是控制台,都是用API函数CreateFile来打开或创建的。该函数的声明为:

HANDLE CreateFile( 
  LPCTSTR lpFileName, // 文件名 
  DWORD dwDesiredAccess, // 访问模式 
  DWORD dwShareMode, // 共享模式 
  LPSECURITY_ATTRIBUTES lpSecurityAttributes, // 通常为NULL 
  DWORD dwCreationDistribution, // 创建方式 
  DWORD dwFlagsAndAttributes, // 文件属性和标志 
  HANDLE hTemplateFile // 临时文件的句柄,通常为NULL


如果调用成功,那么该函数返回文件的句柄,如果调用失败,则函数返回:


INVALID_HANDLE_VALUE
 
在用ReadFile和WriteFile读写时,既可以同步执行,也可以异步执行。ReadFile和WriteFile函数是否为执行异步操作是由CreateFile函数决定的。如果在调用CreateFile创建句柄时指定了FILE_FLAG_OVERLAPPED标志,那么调用ReadFile和WriteFile对该句柄进行的读写操作就是异步的,如果未指定异步标志,则读写操作是同步的。在同步执行时,函数直到操作完成后才返回。这意味着在同步执行时线程会被阻塞,从而导致效率下降。在异步执行时,即使操作还未完成,调用的函数也会立即返回。费时的I/O操作在后台进行,这样线程就可以干别的事情。这样可以大大的提高效率。这一点是值得我们学习和借鉴的,对于我们在文件的操作方面也可以对win32系统进行封装来提高文件操作的效率。

标签:封装,MySQL,数据库,函数
0
投稿

猜你喜欢

  • MySQL去重的方法整理

    2024-01-27 07:04:42
  • MySQL数据库开启、关闭、查看函数功能的方法

    2024-01-20 00:41:13
  • python如何变换环境

    2021-06-02 19:19:44
  • 画pytorch模型图,以及参数计算的方法

    2023-09-25 09:12:58
  • Django应用程序入口WSGIHandler源码解析

    2021-07-09 04:33:22
  • 详解Vue中添加过渡效果

    2024-04-27 16:04:29
  • 解决Python报错:SyntaxError: invalid character ‘,‘ (U+FF0C)

    2023-01-24 06:12:57
  • 三谈Iframe自适应高度

    2010-08-03 13:04:00
  • MySQL数据库中的重要数据应当如何保护

    2008-12-17 15:56:00
  • 详解如何利用docker快速构建MySQL主从复制环境

    2024-01-25 08:25:33
  • element-ui表格列金额显示两位小数的方法

    2024-04-26 17:41:10
  • K最近邻算法(KNN)---sklearn+python实现方式

    2023-09-14 15:29:31
  • python中的集合及集合常用的使用方法

    2023-05-04 11:14:11
  • Gorm更新零值问题解决思路与过程

    2024-04-25 13:18:25
  • mysql 存在该记录则更新,不存在则插入记录的sql

    2024-01-29 07:19:24
  • 详解go-admin在线开发平台学习(安装、配置、启动)

    2023-08-26 15:27:31
  • 在layui下对元素进行事件绑定的实例

    2024-04-22 22:17:27
  • 在Golang代码中如何自动生成版本号的方法示例

    2023-10-14 23:25:36
  • MySQL如何根据不同条件联查不同表的数据if/case

    2024-01-21 14:20:10
  • pycharm2022.2远程连接服务器调试代码实现

    2022-11-17 12:12:48
  • asp之家 网络编程 m.aspxhome.com