API串口通信实例.doc

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
API串口通信实例

第一节? 实现串口通讯的函数及串口编程简介 ? API函数不仅提供了打开和读写通讯端口的操作方法,还提供了名目繁多的函数以支持对串行通讯的各种操作。常用函数及作用下: 函数名??????????????????? 作用 CreateFile??????????????? 打开串口 GetCommState????????????? 检测串口设置 SetCommState????????????? 设置串口 BuilderCommDCB??????????? 用字符串中的值来填充设备控制块 GetCommTimeouts?????????? 检测通信超时设置 SetCommTimeouts?????????? 设置通信超时参数 SetCommMask?????????????? 设定被监控事件 WaitCommEvent???????????? 等待被监控事件发生 WaitForMultipleObjects??? 等待多个被监测对象的结果 WriteFile???????????????? 发送数据 ReadFile????????????????? 接收数据 GetOverlappedResult?????? 返回最后重叠(异步)操作结果 PurgeComm???????????????? 清空串口缓冲区,退出所有相关操作 ClearCommError??????????? 更新串口状态结构体,并清除所有串口硬件错误 CloseHandle?????????????? 关闭串行口 用Windows API编写串口程序本身是有巨大优点的,因为控制能力会更强,效率也会更 高。 ?? API编写串口,过程一般是这样的: ?? 1、 创建串口句柄,用CreateFile; ?? 2、 对串口的参数进行设置,其中比较重要的是波特率(BaudRate),数据宽度(BytesBits),奇偶校验(Parity),停止位(StopBits),当然,重要的还有端口号(Port); ?? 3、 然后对串口进行相应的读写操作,这时候用到ReadFile和WriteFile函数; 4、????? 读写结束后,要关闭串口句柄,用CloseFile。 下面依次讲述各个步骤的过程。 ?? ? 第二节? 创建串口句柄打开串口 ? 从字面上去理解,大家也可以发现CreateFile实际上表明Windows是把串口当作一个文件来处理的,所以它也有文件那样的缓冲区、句柄、读写错误等,不同的是,这个文件名字只有固定的几个(一般为四个),而且始终存在(EXSITING),而且在调用CreateFile的时候请注意它的参数。CreateFile函数原型如下: ?? HANDLE CreateFile(LPCTSTR lpFileName, ???????????????????? DWORD dwDesiredAccess, ???????????????????? DWORD dwShareMode, ???????????????????? LPSECURITY_ATTRIBUTES lpSecurityAttributes, ???????????????????? DWORD dwCreationDisposition,? ???????????????????? DWORD dwFlagsAndAttributes, ???????????????????? HANDLE hTemplateFile ); lpFileName:指向一个以NULL结束的字符串,该串指定了要创建、打开或截断的文件、管道、通信源、磁盘设备或控制台的名字。当用CreateFile打开串口时,这个参数可用“COM1”指定串口1,用“COM2”指定串口2,依此类推。 dwDesireAccess: 指定对文件访问的类型,该参数可以为GENERIC_READ(指定对该文件的读访问权)或GENERIC_WRITE(指定该文件的写访问权)两个值之一或同时为为这两个值。用ENERIC_READ|GENERIC_WRITE则指定可对串口进行读写; dwShareMode:指定此文件可以怎样被共享。因为串行口不支持任何共享模式,所以dwShareMode必须设为0; lpSecurityAttributes定义安全属性,一般不用,可设为NULL。Win 9x下该参数被忽略; dwCreationDistribution定义文件创建方式, 对串口必须设为OPEN_EXISTING,表示打开已经存在的文件; dwFlagsAndAttributes为该文件指定定义文件属性和标志,这个程序中设为FILE_FLAG_OVERLAPPED,表示异步通信方式; ?? hTem

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档