细化解析:Mysql数据库对文件操作的封装

作者:39081 来源:赛迪网 时间:2008-11-27 16:32: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系统进行封装来提高文件操作的效率。

标签:
0
投稿

猜你喜欢

  • Python 详解通过Scrapy框架实现爬取百度新冠疫情数据流程

    2023-04-03 12:13:33
  • Django框架实现在线考试系统的示例代码

    2021-05-24 23:07:00
  • 如何在python中实现ECDSA你知道吗

    2023-03-14 14:07:17
  • 在django admin详情表单显示中添加自定义控件的实现

    2023-09-24 18:56:00
  • 详解在Python的Django框架中创建模板库的方法

    2023-08-15 10:32:56
  • python处理json数据中的中文

    2021-10-02 07:11:10
  • 七十六个网站用户体验要点

    2010-08-11 14:52:00
  • Python画图常用命令大全(详解)

    2023-04-17 15:20:16
  • Django rest framework分页接口实现原理解析

    2023-08-22 21:26:36
  • Vue + Webpack + Vue-loader学习教程之相关配置篇

    2024-04-29 13:10:40
  • Python 中的 global 标识对变量作用域的影响

    2021-11-24 00:16:47
  • Python数据类型及常用方法

    2022-09-22 08:09:19
  • ProC 连接Oracle代码

    2009-06-10 18:12:00
  • python sys模块sys.path使用方法示例

    2023-01-12 22:52:15
  • python实现scrapy爬虫每天定时抓取数据的示例代码

    2022-05-04 22:33:18
  • golang gorm框架数据库的连接操作示例

    2024-01-21 06:52:56
  • python实现图书借阅系统

    2022-03-26 07:46:32
  • 分享8点超级有用的Python编程建议(推荐)

    2022-03-31 08:05:57
  • 让大家看看Object标签的强大功能---多用途

    2009-02-21 10:18:00
  • MySQL delete删除数据后释放磁盘空间的操作方法

    2024-01-18 21:00:16
  • asp之家 网络编程 m.aspxhome.com