2024年3月14日发(作者:)

在Win32下,可以使用两种编程方式实现串口通信,其一是使用ActiveX控件,这种方法程

序简单,但欠灵活。其二是调用Windows的API函数,这种方法可以清楚地掌握串口通信

的机制,并且自由灵活。本文我们只介绍API串口通信部分。

串口的操作可以有两种操作方式:同步操作方式和重叠操作方式(又称为异步操作

方式)。同步操作时,API函数会阻塞直到操作完成以后才能返回(在多线程方式中,虽然

不会阻塞主线程,但是仍然会阻塞监听线程);而重叠操作方式,API函数会立即返回,操

作在后台进行,避免线程的阻塞。

无论那种操作方式,一般都通过四个步骤来完成:

(1) 打开串口

(2) 配置串口

(3) 读写串口

(4) 关闭串口

(1) 打开串口

Win32系统把文件的概念进行了扩展。无论是文件、通信设备、命名管道、邮件槽、磁

盘、还是控制台,都是用API函数CreateFile来打开或创建的。该函数的原型为:

HANDLE CreateFile( LPCTSTR lpFileName,

DWORD dwDesiredAccess,

DWORD dwShareMode,

LPSECURITY_ATTRIBUTES lpSecurityAttributes,

DWORD dwCreationDistribution,

DWORD dwFlagsAndAttributes,

HANDLE hTemplateFile);

lpFileName:将要打开的串口逻辑名,如“COM1”;

dwDesiredAccess:指定串口访问的类型,可以是读取、写入或二者并列;

dwShareMode:指定共享属性,由于串口不能共享,该参数必须置为0;

lpSecurityAttributes:引用安全性属性结构,缺省值为NULL;

dwCreationDistribution:创建标志,对串口操作该参数必须置为OPEN_EXISTING;

dwFlagsAndAttributes:属性描述,用于指定该串口是否进行异步操作,该值为

FILE_FLAG_OVERLAPPED,表示使用异步的I/O;该值为0,表示同步I/O操作;

hTemplateFile:对串口而言该参数必须置为NULL;

同步I/O方式打开串口的示例代码:

HANDLE hCom; //全局变量,串口句柄

hCom=CreateFile("COM1",//COM1口

GENERIC_READ|GENERIC_WRITE, //允许读和写

0, //独占方式

NULL,

OPEN_EXISTING, //打开而不是创建

0, //同步方式

NULL);

if(hCom==(HANDLE)-1)

{

AfxMessageBox("打开COM失败!");

return FALSE;

}

return TRUE;

重叠I/O打开串口的示例代码: HANDLE hCom; //全局变量,串口句柄

hCom =CreateFile("COM1", //COM1口

GENERIC_READ|GENERIC_WRITE, //允许读和写

0, //独占方式

NULL,

OPEN_EXISTING, //打开而不是创建

FILE_ATTRIBUTE_NORMAL|FILE_FLAG_OVERLAPPED, //重叠方式

NULL);

if(hCom ==INVALID_HANDLE_VALUE)

{

AfxMessageBox("打开COM失败!");

return FALSE;

}

return TRUE;

(2)、配置串口

在打开通讯设备句柄后,常常需要对串口进行一些初始化配置工作。这需要通过一

个DCB结构来进行。DCB结构包含了诸如波特率、数据位数、奇偶校验和停止位数等信息。

在查询或配置串口的属性时,都要用DCB结构来作为缓冲区。

一般用CreateFile打开串口后,可以调用GetCommState函数来获取串口的初始配

置。要修改串口的配置,应该先修改DCB结构,然后再调用SetCommState函数设置串口。

DCB结构包含了串口的各项参数设置,下面仅介绍几个该结构常用的变量:

typedef struct _DCB{

………

//波特率,指定通信设备的传输速率。这个成员可以是实际波特率值或者下面的常量值

之一:

DWORD BaudRate;

CBR_110,CBR_300,CBR_600,CBR_1200,CBR_2400,CBR_4800,CBR_9600,CBR_19200,

CBR_38400,

CBR_56000, CBR_57600, CBR_115200, CBR_128000, CBR_256000, CBR_14400

DWORD fParity; // 指定奇偶校验使能。若此成员为1,允许奇偶校验检查

BYTE ByteSize; // 通信字节位数,4—8

BYTE Parity; //指定奇偶校验方法。此成员可以有下列值: