串口操作之API篇 CreateFile

CreateFile
http://bbs.fishc.com/thread-72944-1-1.html

(出处: 鱼C论坛)

------------------------------------------------------------------------

CreateFile用于打开串口,如果操作成功,返回一个句柄.

1 function CreateFile(lpFileName: PChar; dwDesiredAccess, dwShareMode: DWORD;   
2   lpSecurityAttributes: PSecurityAttributes; dwCreationDisposition, dwFlagsAndAttributes: DWORD;   
3   hTemplateFile: THandle): THandle; stdcall;  

来解释一下参数.
lpFileName:要打开的串口逻辑名称,比如:COM1,COM2....,记住一点,如果打开的串口大于10,直接的COM10是打不开的,需要改成 \\.\COM10 才可以.
dwDesiredAccess:访问串口的方式,可读,可写,或者是可读&可写.
dwShareMode:共享模式,串口不可共享,这个要填写0.
lpSecurityAttributes:安全属性的结构体指针,缺省为nil.
dwCreationDisposition:创建标志,操作串口应该设置为OPEN_EXISTING.
dwFlagsAndAttributes:属性和标志位,如果需要异步I/O的操作,需要增加该标志FILE_FLAG_OVERLAPPED.缺省为FILE_ATTRIBUTE_NORMAL.异步I/O的操作不在此讨论,有兴趣可以看看侯捷翻译的win32多线程程序设计.
hTemplateFile:模板文件句柄,串口操作,这个要填写0.

其他的详细参数,可以参考delphi的帮助,或者MSDN.

例子:

1 FCommHandle := CreateFile(PCHAR(FCommName), 
                            GENERIC_READ or GENERIC_WRITE,   
                            0, 
                            nil, 
                            OPEN_EXISTING, 
                            FILE_ATTRIBUTE_NORMAL, 
                            0);   
3 FCommHandle := CreateFile(PCHAR('\\.\COM12'), GENERIC_READ or GENERIC_WRITE,   
4                       0, nil, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);  


猜你喜欢

转载自blog.csdn.net/aidem_brown/article/details/80251551