`
lxlsp
  • 浏览: 6905 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

CreateFile 说明

阅读更多

说明:CreateFile函数创建或打开对象(文件、pipes、邮槽、通信资源、磁盘驱动器(仅适用于windowsNT)、控制台、文件夹(仅用于打开)),并返回一个可以用来访问这些对象的句柄。

 

HANDLE CreateFile(
 LPCTSTR lpFileName,    //指向文件名的指针
 DWORD dwDesiredAccess,    //访问模式(写/读)
 DWORD dwShareMode,    //共享模式
 LPSECURITY_ATTRIBUTES lpSecurityAttributes, //指向安全属性的指针
 DWORD dwCreationDisposition,   //如何创建
 DWORD dwFlagsAndAttributes,   //文件属性
 HANDLE hTemplateFile    //用于复制文件句柄
);

 

参数说明:

lpFileName :指向一个空结尾字符串。该参数指定了用于创建或打开句柄的对象。指向一个空结尾字符串。该参数指定了 用于创建或打开句柄的对象。

 

dwDesiredAccess:指定对象的访问方式,程序可以获得读访问权,写访问权,读写访问权或者是询问设备("device query") 访问权。这个参数可以是下列值的任意组合

        0:指定询问访问权.程序可以在不直接访问设备的情况下查询设备的属性.

        GENERIC_READ: 指定读访问权.可以从文件中读取数据,并且移动文件指针.可以和GENERIC_WRITE组合
    成为"读写访问权".

        GENERIC_WRITE:指定写访问权.可以从文件中写入数据,并且移动文件指针.可以和GENERIC_READ组合
    成为"读写访问权".

 

dwShareMode :设置位标志指明对象如休共享.如果参数是0, 对象不能够共享. 后续的打开对象的操作将会失败,直到该对象的句柄关闭.

        FILE_SHARE_DELETE:后续的仅仅请求删除访问权的打开操作将会成功.

        FILE_SHARE_READ:后续的仅仅请求读访问权的打开操作将会成功.

        FILE_SHARE_WRITE :后续的仅仅请求写访问权的打开操作将会成功.

 

lpSecurityAttributes: 指向一个 SECURITY_ATTRIBUTES 结构的指针用于确定如何在子进程中继承这个句柄.如果这个参数是NULL,则该句柄不可继承.
 

dwCreationDisposition:指定当文件存在或者不存在时如何动作。关于这个参数更多的信息,参考批注部分。这个参数必须是一个或多个下列值。

       CREATE_NEW : 创建一个新文件. 如果该文件已经存在函数则会失败.

       CREATE_ALWAYS:创建一个新文件.如果该文件已经存在,函数将覆盖已存在的文件并清除已存在的文件属性

       OPEN_EXISTING :打开一个文件,如果文件不存在函数将会失败.
       OPEN_ALWAYS  :如果文件存在,打开文件. 如果文件不存在,并且参数中有CREATE_NEW标志,则创建文件.

       TRUNCATE_EXISTING:打开一个文件,每次打开,文件将被截至0字节.调用进程必须用GENERIC_WRITE访问模式打开文件.如果文件不存在则函数就会失败.

 

dwFlagsAndatributes:为文件指定属性和标志位。该参数可以接收下列属性的任意组合.除非其它所有的文件属性忽略FILE_ATTRIBUTE_NORMAL.

       FILE_ATTRIBUTE_ARCHIVE:文件将被存档,程序使用此属性来标志文件去备份或移除

       FILE_ATTRIBUTE_HIDDEN:文件被隐藏,它不会在一般文件夹列表中被装载.

       FILE_ATTRIBUTE_NORMAL:文件没有被设置任何属性

       FILE_ATTRIBUTE_OFFLINE :文件的数据没有被立即用到。指出正在脱机使用该文件。

       FILE_ATTRIBUTE_READONLY:这个文件只可读取.程序可以读文件,但不可以在上面写入内容,也不可删除.

       FILE_ATTRIBUTE_SYSTEM:文件是系统的一部分,或是系统专用的.

       FILE_ATTRIBUTE_TEMPORARY:文件被使用后,文件系统将努力为(文件的)所有数据的迅速访问保持一块
     内存。临时文件应当在程序不用时及时删除。

     

dwFlagAndAttributes可以接受下列标志的任意组合。

FILE_FLAG_WRITE_THROUGH:指示系统通过快速缓存直接写入磁盘,

FILE_FLAG_OVERLAPPED:指示系统初始化对象, 此操作将对进程设置一个引用计数并返回ERROR_IO_PENDING.
     处理完成后, 指定对象将被设置为信号状态. 当你指定FILE_FLAG_OVERLAPPED时,读写文件的函数必须指定一个OVERLAPPED结构.并且. 当FILE_FLAG_OVERLAPPED被指定, 程序必须执行重叠参数(指向OVERLAPPED结构)去进行文件的读写.这个标志也可以有超过一个操作去执行. 

 FILE_FLAG_NO_BUFFERING:指示系统不使用快速缓冲区或缓存,当和FILE_FLAG_OVERLAPPED组合,该标志给出最大的异步操作量, 因为I/O不依赖内存管理器的异步操作.然而,一些I/O操作将会运行得长一些,因为数据没有控制在缓存中. 当使用FILE_FLAG_NO_BUFFERING打开文件进行工作时,程序必须达到下列要求:文件的存取开头的字节偏移量必须是扇区尺寸的整倍数. 文件存取的字节数必须是扇区尺寸的整倍数.例如,如果扇区尺寸是512字节程序就可以读或者写512,1024或者2048字节,但不能够是335,981或者7171字节.进行读和写操作的地址必须在扇区的对齐位置,在内存中对齐的地址是扇区尺寸的整倍数.一个将缓冲区与扇区尺寸对齐的途径是使用VirtualAlloc函数. 它分配与操作系统内存页大小的整倍数对齐的内存地址.因为内存页尺寸和扇区尺寸--2都是它们的幂.这块内存在地址中同样与扇区尺寸大小的整倍数对齐.程序可以通过调用GetDiskFreeSpace来确定扇区的尺寸.

FILE_FLAG_RANDOM_ACCESS:指定文件是随机访问,这个标志可以使系统优化文件的缓冲.

FILE_FLAG_SEQUENTIAL_SCAN:指定文件将从头到尾连续地访问.这个标志可以提示系统优化文件缓冲. 如果程序在随机访问文件中移动文件指针,优化可能不会发生;然而,正确的操作仍然可以得到保证。指定这个标志可以提高程序以顺序访问模式读取大文件的性能, 性能的提高在许多程序读取一些大的顺序文件时是异常明显的.但是可能会有小范围的字节遗漏.

 FILE_FLAG_DELETE_ON_CLOSE:指示系统在文件所有打开的句柄关闭后立即删除文件.不只有你可以指定FILE_FLAG_DELETE_ON_CLOSE。如果没有使用FILE_SHARE_DELETE,后续的打开文件的请求将会失败.

FILE_FLAG_BACKUP_SEMANTICS:指示系统为文件的打开或创建执行一个备份或恢复操作. 系统保证调用进程忽略文件的安全选项,倘若它必须有一个特权.则相关的特权则是SE_BACKUP_NAME和SE_RESTORE_NAME.你也可以使用这个标志获得一个文件夹的句柄,一个文件夹句柄能够象一个文件句柄 一样传给某些Win32函数。

FILE_FLAG_POSIX_SEMANTICS :指明文件符合POSIX标准.这是在MS-DOS与16位Windows下的标准.

FILE_FLAG_OPEN_REPARSE_POINT :指定这个标志制约NTFS分区指针.该标志不能够和CREAT_ALWAYS一起使用.

 FILE_FLAG_OPEN_NO_RECALL :指明需要文件数据,但是将继续从远程存储器中接收.它不会将数据存放在本地存储器中.这个标志由远程存储系统或等级存储管理器系统使用.

 

hTemplateFile:为GENERIC_READ访问的模式指定一个句柄到模板文件.模板文件在文件开始创建后提供文件属性和扩展属性.

 

 

返回值

如果函数成功,返回一个打开的指定文件的句柄。

如果指定文件在函数调用前已经存在并且dwCreation参数是CREATE_ALWAYS 或者OPEN_ALWAYS,调用GetLastError就会返回ERROR_ALREADY_EXISTS(表示函数成功)。

如果函数文件在调用前不存在则会返回0.

如果函数失败,返会值会是INVALID_HANDLE_VALUE. 更多的错误信息可以调用GetLastError来获得.

 

分享到:
评论

相关推荐

    CreateFile_based_rootkit

    错误说明 NtCreateFile可以使用“”之类的名称创建和访问目录。但是CreateFile无法做到。按照相同的示例,它将其更改为“”,这是一个完全不同的目录。它是由KERNELBASE!_imp__RtlDosPathNameToRelativeNtPathName_...

    Create File

    CreateFile,ReadFile,WriteFile,DeviceIoControl,CloseHandle函数说明

    实验五 复制文件

    完成一个目录复制命令mycp,包括目录下的文件和子目录, 运行结果如下: ...说明: Linux: creat,read,write等系统调用,要求支持软链接 Windows: CreateFile(), ReadFile(), WriteFile(), CloseHandle()等函数

    delphi 运用两种方法读取电脑的所有串口号

    测试通过,运行两种方法读取电脑的所有串口号

    react-gen:用于生成React成分的生成器。 生成.test(笑话)、. stories(故事书)和.mock文件

    按照说明安装以下软件包: 安装及使用 $ npm i -g @dennisschoepf/react-gen $ react-gen 或仅与 $ npx @dennisschoepf/react-gen 然后,将要求您提供组件的名称,并能够从许多模板中进行选择。 选件 当前不支持其他...

    C语言源代码格式化 完工 V1.04 20120226 1946.7z

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    windows用户称拦截api

    5 附件代码下载以及说明 一:摘要 拦截api的技术有很多种,大体分为用户层和内核层的拦截.这里只说说用户层的拦截(内核层也可以用,关键是让你的拦截程序获得ring0特权).而用户层也分为许多种:修改PE文件导入表...

    C语言源代码格式化 完工 V1.05 20120229 1804.7z

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    ssi自动生成底层代码(纯手写)

    请仔细阅读此说明:自动生成action、service、dao、sqlmap类 以及applicationContext.xml、struts.xml。 只需要将相应的代码粘贴到相应的位置即可。使用方法:打开工程,在createfile.java 类里填写数据表名以及生成...

    C语言源代码格式化 完工 V1.09 20120821 2116.7z

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    NTFS磁盘还原,支持动态穿透写文件

    测试本程序请在虚拟机中测试,以上程序由于都用CREATEFILE 打开磁盘分区,所以有些敏感杀软可能误认为病毒。 支持全盘还原,可还原在用户下的一切磁盘操作,完全阻止病毒入侵。可防止用户删除分区。格式化等一...

    C语言源代码格式化 完工 小文版本 V1.10 20120831 0955.zip

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    C语言源代码格式化 完工 V1.08 20120801 1627.7z

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    驱动程序FUZZ工具 Kdriver

    ####一些环境说明: 编译环境:Windows 10 x64 build 1607 项目IDE:VS2013 测试环境:Windows 7 x86、Windows 10 x86 build 1607 参数介绍: "-l" :开启日志记录模式(不会影响主日志记录模块) "-s" :驱动...

    j2se项目源码及介绍_飞鸽传书

    private void createFile(Object obj) 创建文件。 private void createDirectory(Object obj) 创建目录。 private void dealServerQuit() 处理服务端退出。 private void closeClient() 断开连接。 内部...

    Wininet API 写的下载器类,可获取文件名,下载,等等。

    HANDLE hFile = CreateFile(szFileSavePath,GENERIC_WRITE,FILE_SHARE_WRITE,NULL,OPEN_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL); if(hFile == INVALID_HANDLE_VALUE) { InternetCloseHandle(hInternetUrl);...

    C语言源代码格式化 完工 V1.03 20120112 1536.7z

    说明: 除非特别声明,所有程序均使用VC++6.0 MFC编写。 所有程序均为练手用,放弃一切权利,同时不承担任何责任。 显式遵照 GPL v3.0标准。 QuoteCorrection 20110722 1119.7z 处理 清风徐来 水波不兴 邮件...

    Visual Basic.NET自动化系统监控--RS-232串行通信.(清华出版.范逸之.廖锦棋)

    3.2.2 CreateFile/CloseHandle (打开/关闭通信端口) 81 3.2.3 GetCommState (取得通信端口参数) 82 3.2.4 SetCommState (设置通信端口参数) 84 3.2.5 WriteFile (输出数据至通信端口) 85 3.2.6 ReadFile (自通信...

    基于javadbf-0[1].4.0.jar包的dbf文件操作源码

    在尽量不影响效率的情况下,增加了对dbf各个方面的处理功能:查询,创建,copy文件结构等功能,目前没有发现bug,说明文档在程序中很详细,以下是我的说明演示部分代码,此源码需要5个积分,主要是因为可能需求不多...

    VC++6.0核心编程源码.rar

    观察图1-1,你会看到我已经调用了CreateFile函数。该函数返回INVALID_HANDLE_VALUE(-1)的HANDLE,表示它未能打开指定的文件。但是Watch窗口向我们显示最后错误代码(即如果我调用GetLastErro函数,该函数返回的...

Global site tag (gtag.js) - Google Analytics