欢迎光临
我们一直在努力

Mysql对文件操作的封装-JSP教程,数据库相关

建站超值云服务器,限时71元/月

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系统进行封装来提高文件操作的效率。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » Mysql对文件操作的封装-JSP教程,数据库相关
分享到: 更多 (0)