串口编程的一般步骤及相关函数讲解
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
用Windows API进行串口编程的一般步骤及相关函数讲解
------分隔线----------------------------
虽然使用诸如 CSerialPort VC串口类,MSComm VC 串口控件等非常方便,但有时这些控件并不适合自己的特殊需求,所以有必要了解一下基于Windows API的串口编程方法,下面介绍一下API串口编程的一般步骤及相关串口API函数。
串口操作一般有四步,分别是:
1) 打开串口
2) 配置串口
3) 读写串口
4) 关闭串口
1、打开串口
在《VC 打开串口》一文中我们已经单独介绍过如果利用API打开串口的方法,打开串口是用API函数CreateFile来打开或创建的。该函数的原型为:
1 HANDLE CreateFile( LPCTSTR lpFileName,
2 DWORD dwDesiredAccess,
3 DWORD dwShareMode,
4 LPSECURITY_ATTRIBUTES lpSecurityAttributes,
5 DWORD dwCreationDistribution,
6 DWORD dwFlagsAndAttributes,
7 HANDLE hTemplateFile);
参数详解:
lpFileName:将要打开的串口逻辑名,如COM1;
dwDesiredAccess:指定串口访问的类型,可以是读取、写入或二者并列;
dwShareMode:指定共享属性,由于串口不能共享,该参数必须置为0;
lpSecurityAttributes:引用安全性属性结构,缺省值为NULL;
dwCreationDistribution:创建标志,对串口操作该参数必须置为OPEN_EXISTING;
dwFlagsAndAttributes:属性描述,用于指定该串口是否进行异步操作,该值为FILE_FLAG_OVERLAPPED,表示使用异步的I/O;该值为0,表示同步I/O操作;
hTemplateFile:对串口而言该参数必须置为NULL;
串口的操作可以有两种操作方式:同步操作方式和重叠操作方式(也称为异步操作方式)。同步操作时,API函数会阻塞直到操作完成以后才能返回(在多线程方式中,虽然不会阻塞主线程,但是仍然会阻塞监听线程);而重叠操作方式,API函数会立即返回,操作在后台进行,避免线程的阻塞。
同步I/O方式打开串口的示例:
8 HANDLE hCom; //全局变量,串口句柄
9 hCom=CreateFile(COM1,//COM1口
10 GENERIC_READ|GENERIC_WRITE, //允许读和写
11 0, //独占方式
12 NULL,
13 OPEN_EXISTING, //打开而不是创建
14 0, //同步方式
15 NULL);
16 if(hCom==(HANDLE)-1)
17 {
18 AfxMessageBox(打开COM失败!);
19 return FALSE;
20 }
21 return TRUE;
重叠I/O打开串口的示例:
22 HANDLE hCom; //全局变量,串口句柄
23 hCom =CreateFile(COM1, //COM1口
24 GENERIC_READ|GENERIC_WRITE, //允许读和写
25 0, //独占方式
26 NULL,
27 OPEN_EXISTING, //打开而不是创建
28 FILE_ATTRIBUTE_NORMAL|FILE_FLAG_OVERLAPPED, //重叠方式
29 NULL);
30 if(hCom ==INVALID_HANDLE_VALUE)
31 {
32 AfxMessageBox(打开COM失败!);
33 return FALSE;
34 }
35 return TRUE;
2、配置串口
在打开通讯设备句柄后,常常需要对串口进行一些初始化配置工作。这需要通过一个DCB结构来进行。DCB结构包含了诸如波特率、数据位数、奇偶校验和停止位数等信息。在查询或配置串口的属性时,都要用DCB结构来作为缓冲区。
一般用CreateFile打开串口后,可以调用GetCommState函数来获取串口的初始配置。要修改串口的配置,应该先修改DCB结构,然后再调用SetCommState函数设置串口。
DCB结构包含了串口的各项参数设置,下面仅介绍几个该结构常用的变量:
36 typedef struct _DCB{
37 &&&
38 //波特率,指定通信设备的传输速率。这个成员可以是实际波特率值或者下面的常量值之一:
39 DWORD BaudRate;
40 CBR_110,CBR_300,CBR_600,CBR_1200,CBR_2400,CBR_4800,CBR_9600,CBR_19200, CBR_38400,
41 CBR_56000, CBR_57600, CBR_115200, CBR_128000, CBR_256000,
CBR_14400
42
43 DWORD fParity; // 指定奇偶校验使能。若此成员为1,允许奇偶校验检查
44 &
45 BYTE ByteSize; // 通信字节位数,48
46 BYTE Parity; //指定奇偶校验方法。此成员可以有下列值:
47 EVENPARITY 偶校验 NOPARITY 无校验
48 MARKPARITY 标记校验 ODDPARITY 奇校验
49 BYTE StopBits; //指定停止位的位数。此成员可以有下列值:
50 ONESTOPBIT 1位停止位 TWOSTOPBITS 2位停止位
51 ONE5STOPBITS 1.5位停止位
52 &&&
53 } DCB;
54 winbase.h文件中定义了以上用到的常量。如下:
55 #define NOPARITY 0
56 #define ODDPARITY 1
57 #define EVENPARITY 2
58 #define ONESTOPBIT 0
59 #define ONE5STOPBITS 1
60 #define TWOSTOPBITS 2
61 #define CBR_110 110
62 #define CBR_300 300
63 #define CBR_600 600
64 #define CBR_1200 1200
65 #define CBR_2400 2400
66 #define CBR_4800 4800
67 #define CBR_9600 9600
68 #define CBR_14400 14400
69 #define CBR_19200 19200
70 #define CBR_38400 38400
71 #define CBR_56000 56000
72 #define CBR_57600 57600
73 #define CBR_115200 115200
74 #define CBR_128000 128000
75 #define CBR_256000 256000
GetCommState函数可以获得COM口的设备控制块,从而获得相关参数:
76 BOOL GetCommState(
77 HANDLE hFile, //标识通讯端口的句柄
78 LPDCB lpDCB //指向一个设备控制块(DCB结构)的指针
79 );
80 SetCommState函数设置COM口的设备控制块:
81 BOOL SetCommState(
82 HANDLE hFile,