串口之CreateFile 函数具体解释

HANDLE CreateFile(

LPCTSTR lpFileName, //指向文件名称的指针

DWORD dwDesiredAccess, //訪问模式(写/读)

DWORD dwShareMode, //共享模式

LPSECURITY_ATTRIBUTES lpSecurityAttributes, //指向安全属性的指针

DWORD dwCreationDisposition, //怎样创建

DWORD dwFlagsAndAttributes, //文件属性

HANDLE hTemplateFile //用于拷贝文件句柄

);

參数列表:

lpFileName

//指向一个空结尾字符串。

该參数指定了用于创建或打开句柄的对象。假设lpFileName的对 象是一个路径,则有一个最大字符数的限制。

不能超过常量(MAX_PATH).这个限制指示了CreateFile函数怎样解析路径.

dwDesiredAccess

//指定对象的訪问方式,程序能够获得读訪问权,写訪问权,读写訪问权或者是询问设备("device query") 訪问权.

这个參数能够是下列值的随意组合:

0             //指定询问訪问权.程序能够在不直接訪问设备的情况下查询设备的属性.

GENERIC_READ //指定读訪问权.能够从文件里读取数据,而且移动文件指针.能够和GENERIC_WRITE组合成为"读写訪问权". GENERIC_WRITE //指定写訪问权.能够从文件里写入数据,而且移动文件指针.能够和GENERIC_READ组合成为"读写訪问权".

dwShareMode

//设置位标志指明对象如休共享.假设參数是0, 对象不可以共享. 兴许的打开对象的操作将会失败,直到该对象的句柄关闭.

使用一个或多个下列值的组合来共享一个对象:

FILE_SHARE_DELETE //WINDOWS NT:兴许的只请求删除訪问权的打开操作将会成功.

FILE_SHARE_READ //兴许的只请求读訪问权的打开操作将会成功.

FILE_SHARE_WRITE //兴许的只请求写訪问权的打开操作将会成功.

lpSecurityAttributes

//指向一个 SECURITY_ATTRIBUTES 结构的指针用于确定怎样在子进程中继承这个句柄.假设这个參数是NULL,则该句柄不可继承.

dwCreationDisposition

//指定当文件存在或者不存在时怎样动作。

关于这个參数很多其它的信息。參考批注部分。这个參数必须是一个或多个下列值:

CREATE_NEW //创建一个新文件. 假设该文件已经存在函数则会失败.

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

OPEN_EXISTING //打开一个文件,假设文件不存在函数将会失败.如查你使用CreateFile函数为设备装载控制台.请查看批注中的"为什么使用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 //WINDOWS NT:指示系统为文件的打开或创建运行一个备份或恢复操作. 系统保证调用进程忽略文件的安全选项,倘若它必须有一个特权.则相关的特权则是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来获得.

时间: 2024-11-05 23:06:10

串口之CreateFile 函数具体解释的相关文章

CreateFile函数详解(确实很详细)

CreateFile The CreateFile function creates or opens the following objects and returns a handle that can be used to accessthe object: files pipes mailslots communications resources disk devices(Windows NT only) consoles directories(open only) CreateFi

CreateFile函数详解

CreateFile函数详解 CreateFile The CreateFile function creates or opens the following objects and returns a handle that can be used to accessthe object: files pipes mailslots communications resources disk devices(Windows NT only) consoles directories(open

串口相关的函数

要使能串口 1 的中断,同时设置抢占优先级为 1,子优先级位 2,初始化的方法是: USART_InitTypeDef USART_InitStructure; NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//串口 1 中断 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=1 ;// 抢占优先级为 1 NVIC_InitStructure.NVIC_IRQChannelSubPrior

fscanf()函数具体解释

曾经解析有规律的文件的时候要么用正則表達式,要么就是傻傻的自己敲代码来解析有规律的文件.今天突然发现c的库函数中有一个现成的能够解析有规律的文件的函数,就是fscanf()函数.哎 曾经自己做了这么多无用功,在这里具体解析一下fscanf函数: fscanf()函数(有点像正則表達式): 功 能: 从一个流中运行格式化输入,fscanf遇到空格和换行时结束,注意空格时也结束. 用 法:int fscanf(FILE *stream, char *format,[argument...]); in

CreateFile 函数详解

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

串口协议匹配函数,避免串口数据接收时顺序换乱错误

按照协议匹配,避免串口数据接收时顺序换乱错误. 包头 长度 地址码 回复状态 校验和 包尾 备注 C0C0 02 F5 AA YY CF 成功 1,转移字符 a)              数据包基本格式中的数据长度.数据和校验和中如果出现关键字C0. CF或CA则需要在其前端加上转义字符CA,即将数据C0.CF或CA发送成CAC0.CACF或CACA,将数据C0C0发送成CAC0CAC0. b)              数据包基本格式中的数据长度length以有效数据的数量为准,即不 需要也

C语言scanf函数详细解释(转)

函数名: scanf 功 能: 执行格式化输入 用 法: int scanf(char *format[,argument,...]); scanf()函数是通用终端格式化输入函数,它从标准输入设备(键盘) 读取输入的信息.可以读入任何固有类型的数据并自动把数值变换成适当的机内格式. 其调用格式为:      scanf("<格式化字符串>",<地址表>); scanf()函数返回成功赋值的数据项数,出错时则返回EOF. 其控制串由三类字符构成: 1.格式化说明

Windows下createfile函数用GENERIC_READ访问模式打不开磁盘

这两天做毕设,快气死了!想读写磁盘扇区,我就百度了,都是这样写的: HANDLE hDevice = CreateFile(TEXT("\\\\.\\PhysicalDrive1", // drive,一般physicaldrive0是主磁盘,我不干,整死了咋整,虚拟机又卡 GENERIC_REAF, // no access to the drive FILE_SHARE_READ ,// share mode, NULL, // default security attribute

malloc函数具体解释

一.原型:extern void *malloc(unsigned int num_bytes); 头文件:#include <malloc.h> 或 #include <alloc.h> (注意:alloc.h 与 malloc.h 的内容是全然一致的.) 功能:分配长度为num_bytes字节的内存块 说明:假设分配成功则返回指向被分配内存的指针,否则返回空指针NULL. 当内存不再使用时,应使用free()函数将内存块释放. 举例:#include<stdio.h>