数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

Mysql数据库对文件操作的封装


发布日期:2022年04月17日
 
Mysql数据库对文件操作的封装

在查看Mysql对文件的操作中它在不同的操作系统上对文件的操作除了使用标准C运行库函数包括opencloseseek等在Win下的文件和目录操作函数使用了CreatFileCloseHandlSetFilePointer等很多人可能不明白为什么对文件的操作要封装出两套函数
其实使用API和标准库函数都可以生成文本文件和二进制文件在这点上没有区别同read()对应的是ReadFile同write()对应的是WriteFile同seek()对应的是SetFilePointer同close对应的是CloseHandle这两套函数都可以使用但是Win 系统把文件的概念进行了扩展无论是文件通信设备命名管道邮件槽磁盘还是控制台都是用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操作在后台进行这样线程就可以干别的事情这样可以大大的提高效率这一点是值得我们学习和借鑒的对于我们在文件的操作方面也可以对win系统进行封装来提高文件操作的效率

上一篇:sqlserver 错误602,未能在sysindexes中

下一篇:SQL语句语法大全