VC 串口编程基础之如何用 VC 打开串口和关闭串口
在对串口进行操作之前都需要先打开串口,VC 串口编程方法分为利用 VC 串口控件(或 VC 串口类)和直接调用Windows底层API函数(我称之为VC API 串口编程)两种方法,不管哪种方法,其实质都是利用底层API函数对串口进行操作,这里我们来看怎么利用API函数来用 VC 打开串口
  Windows 32位以上操作系统(Win98以上)中,将串口(包括其它通信设备)作为文件来处理,所以串口的打开、读写和关闭所用API函数与文件操作函数一样。所以打开串口用CreateFile,读串口用ReadFile,写串口用WriteFile,关闭串口用CloseHandle
一、用VC 打开串口、关闭串口的API函数
1、打开串口用苹果平板电脑怎么用CreateFile,其声明如下:
1 HANDLE CreateFile( 
2   LPCTSTR lpFileName,                        // file name
3   DWORD dwDesiredAccess,                      // access mode
4   DWORD dwShareMode,                          // share mode
5   LPSECURITY_ATTRIBUTES lpSecurityAttributes, // SD
6   DWORD dwCreationDisposition,                // how to create
7   DWORD dwFlagsAndAttributes,                // file attributes
8   HANDLE hTemplateFile                        // handle to template file
9 );
  部分参数解释如下:
lpFileName:指定要打开的串口逻辑名,用字符串表示,如“COM1”“COM2”分别表示串口全国乙卷语文答案1和串口2,若要知道您的电脑有哪此串口,可以打开设备管理器查看,如下图所示,或用丁丁串口调试助手,这个工具启动后会枚举系统当前存在的串口。

马冬梅什么梗
dwDesiredAccess:访问类型,有读(dwDesiredAccess=GENERIC_READ)、写(dwDesiredAccess=GENERIC_WRITE)或两者兼有((dwDesiredAccess=GENERIC_READ | GENERIC_WRITE)。
dwShareMode:指定端口的共享属性,该参数是为那些由许多应用程序共享的文件提供的,对于串口来说是不能共享的,所以它必须设置为0,这就是通信设备与文件之间的主要差别,如果当前的应用程序调用CreateFile打开一个串口,另外一个程序如果已经打开了该串口,此时CreateFile会返回一个错误代码。然而,同一个应用程序的多个线程可以共享由CreateFile返回的端口句柄,并且根据安全性属性设置,该句柄可以被打开端口的应用程序的子程序所继承。
lpSecurityAttributes:安全属性,此参数为一LPSECURITY_ATTRIBUTES结构,此结构定义了一些属性,如果将该参数设为NULL何炅年龄,该端口将被分配为缺省安全属性,缺省安全属性下端口句柄是不能被继承的。
安全属性LPSECURITY_ATTRIBUTES的结构声明如下:
10 typedef struct _SECURITY_ATTRIBUTES { 
11   DWORD  nLength; 
12 腾讯视频怎么取消自动续费该怎么做  LPVOID lpSecurityDescriptor; 
13   BOOL  bInheritHandle; 
14 } SECURITY_ATTRIBUTES, *PSECURITY_ATTRIBUTES; 
结构成员nLength指明该结构的长度, lpSecurityDescriptor指向一个安全描述符,bInheritHandle表明句柄是否能被继承
dwCreationDisposition:指定当此端口正在被其它程序占用时采取的动作,因为串口总是存在的,所以此处必须被设置为OPEN_EXISTING ,该标志告诉Windows不要创建新端口,而是打开一个已经存在的端口。
dwFlagsAndAttributes:描述了端口的各种属性,对于文件来说可能有很多种属性,但对于串口来说,唯一有意义的是设置FILE_FLAG_OVERLAPPED属性,当指定该属性时,端口I/O可以在后台进行,这称之为异步I/O重叠结构,更多信息可查看MSDN或其它参考资料。
hTemplateFile:指向模板文件的句柄,对于串口来说,此参数必须设置为0
  用CreateFile函数打开串COM1的例子如下:
15 HANDLE hCom; 
16 DWORD dwError; 
17
18 hCom    = CreateFile("COM1",        //文件名,这里是串口号
19     GENERIC_READ | GENERIC_WRITE,  //充许读和写
20     0,                              //独占方式
21     NULL, 
22     OPEN_EXISTING,                  //打开而不是创建
23     FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED, //异步I/O重叠结构
24     NULL 
25     );
  然后还应判断端口是否被正常打开,过程如下:
26 if(hCom == INVALID_HANDLE_VALUE) 
27
28     dwErrow = GetLastError();  //取得错误代码
29
  如果发生错误,您可以根据取得的错误代码查询到底是什么原因引起的错误。
2、关闭串口用CloseHandle,其函数声明如下:
30 BOOL CloseHandle( 
31   HANDLE hObject  // handle to object
32 );
  这个函数很简单,参数只有一个,这个参数就是要关闭的端口句柄,就是用CreateFile打开端口时返回的句柄。
二、用VC 打开串口和关闭串口的实例。
  为了直观,程序界面采用MFC编写。创建一个基于对话框MFC应用程序,工程名为OpenCOM,在主对话框中加入两个按钮和组合列表框,如下图所示:

  下拉列表框预先填入数据:COM1COM2COM3COM4,如下图所示:

这样在程序运行后,点击组合列表框就会有四个串行端口可供选择,本站将会在另外一篇文章中介绍如何用枚举串口的方法自动查系统中存在的串口。
  编写打开串口按钮“BN_CLICKED”事件响应代码,内容如下:
33 CString strSel_COM;            //选择想要打开的串口号
34 BOOL    bComOpened  = NULL;    //串口已经被打开标志
35 void COpenCOMDlg::OnBtnOpencom() 
36 {   
37      
38     //取得选定串口号
39     ((CComboBox*)GetDlgItem(IDC_COMLIST))->GetWindowText(strSel_COM);       
40
41     m_hCom = CreateFile( strSel_COM,                //m_hCom的定义为:HANDLE m_hCom;
42                     GENERIC_READ | GENERIC_WRITE,  //读写模式
43                     0,                              //不共享
44                     NULL,                          //默认安全模式
45                     OPEN_EXISTING,                  //打开方式:打开已经存在的端口
46                     NULL, 
47                     NULL); 
48
49     //验证串口是否被正常打开
50     if( m_hCom == INVALID_HANDLE_VALUE ) 
51     { 
52         CString strMsg; 
曹可凡老婆53         strMsg      = "串口" + strSel_COM + "打开失败"; 
54         AfxMessageBox(strMsg); 
55     } 
56     else