快速掌握 Mysql数据库对文件操作的封装

作者:佚名 来源:daem 时间:2009-02-23 17:37:00 

快速掌握 Mysql数据库对文件操作的封装

在查看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
投稿

猜你喜欢

  • 简约的实现——服装网站设计

    2009-03-06 12:43:00
  • 操作Dom节点实现间歇滚动新闻

    2009-10-16 20:51:00
  • python windows安装cuda+cudnn+pytorch教程

    2023-02-04 04:35:02
  • python新手经常遇到的17个错误分析

    2021-08-09 21:46:00
  • oracle dba 应该熟悉的命令

    2009-07-02 12:08:00
  • vue项目打包之后接口出现错误的问题及解决

    2024-05-09 15:11:25
  • HTML5 Canvas 起步(1) - 基本概念

    2009-04-21 13:14:00
  • python 判断网络连通的实现方法

    2021-07-28 06:47:29
  • python3 使用traceback定位异常实例

    2023-05-03 12:42:35
  • Python机器学习库scikit-learn入门开发示例

    2022-10-15 11:40:24
  • 使用Python获取字典键对应值的两种方法

    2022-08-04 05:25:16
  • PHP join()函数用法与实例讲解

    2023-06-02 00:39:19
  • BootStrap modal实现拖拽功能

    2024-04-18 09:43:48
  • JS实现新建文件夹功能

    2024-04-16 09:50:15
  • python模拟点击网页按钮实现方法

    2021-06-18 21:13:09
  • MySQL中基本的多表连接查询教程

    2024-01-13 10:44:15
  • mysql联合索引的使用规则

    2024-01-15 06:18:14
  • Python如何一行输入多个数,并存入列表

    2023-09-27 19:14:56
  • python 实现数字字符串左侧补零的方法

    2021-07-07 10:34:43
  • python简单实现基于SSL的IRC bot实例

    2022-05-29 21:18:03
  • asp之家 网络编程 m.aspxhome.com