有关串口操作的问题,急!,调不出来,还请哪位高手指教!!

tzh127 2005-07-07 08:56:11
我通过Str.Format(_T("Na\n"));//适时测量,Na为传感器提供的串口数据查询命令
Port.PutStr(Str);

向串口发送可是根本无反应,是不是这样向串口发送字符串不行?那应该怎样向串口发送字符串?
...全文
123 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
54783szg 2005-07-07
  • 打赏
  • 举报
回复
1工控系统通常由工控仪器和计算机终端组成,工控仪器和计算机终端之间通过符合RS-232协议的串口通讯,计算终端可以通过双方既定的数据协议,向工控仪器查询状态信号和发送控制信号。
一、硬件协议:定义了RS-232串口的电气规范。
1)DTE/DCE:
一般把工控仪器称为DCE,计算机终端称为DTE,设备之间通过RS-232电缆连接,DCE端采用母连接器(有槽),DTE端采用公连接器(有针)。但如果工控仪器和计算机终端都采用公连接器,则两者都是DTE设备,它们之间的连接应采用零调制解调器方式。
2)RS-232信号:
标准的RS-232管脚通常有D-25PIN和D-9PIN两种类型,常用的信号如下:
信号分类 D-9PIN D-25PIN 信号名称 信号缩写 信号方向
数据信号 3 2 数据传输 TD DTE->DCE
2 3 接收数据 RD DTE<-DCE
控制信号 7 4 请求发送 RTS DTE<-DCE
8 5 清除发送 CTS DTE<-DCE
6 6 数据发送就绪 DSR DTE<-DCE
1 8 载波检测 CD DTE<-DCE
4 20 数据终端就绪 DTR DTE->DCE
9 22 振铃指示 RI DTE<-DCE
接地信号 5 7 接地信号 GND
3)零调制解调连接(ZERO MODEM):
ZERO MODEM处理DTE和DTE设备的对称连接,其连接原理为,一方的传送数据信号为另一方的接收数据信号,一方的控制请求信号为另一方的控制应答信号,接地信号互连。连接示意如下:
信号分类 DTE DTE
数据信号 TD-- RD
RD-- TD
控制信号 RTS-- CTS
CTS-- RTS
(DSR-DCD-RI)-- DTR
DTR-- (DSR-DCD-RI )
接地信号 GND-- GND
二、软件协议:定义了DTE的串口配置,DTE和DCE之间连接协议和数据传输协议。
1)串口参数配置:
波特率(BaudRate):在CBR_110到CBR_256000之间指定,参照仪器指定
数据位(ByteSize):每个字节的位数,一般用7或8,默认为8
停止位(StopBits):停止位的位数,一般有:ONESTOPBIT、TOWSTOPBITS、ONE5STOPBITS,默认为ONESTOPBIT
奇偶校验(Parity): 定义了奇偶校验的模式,一般有:NO_PARITY、EVEN_PARITY、ODD_PARITY,默认NO_PARITY
流量控制(FlowCtrl):定义了流量控制方式,一般有:无控制、硬件方式、XON/XOFF方式,详见握手协议。
2)握手协议:常见有硬件方式RTS/CTS和DTR/DSR方式,软件方式有XON/XOFF和自定义的方式。

RTS/CTS:对于DTE来说,设置OutCtsFlow则CTS低水平位时停止输出,直至高水平位时恢复输出。设置RtsControl为HANDSHAKE则当输入缓冲区数据小于1/4时,DTE将RTS置为高水平位,通知DCE可以传输数据,当输入缓冲区数据大于3/4时,DTE将RTS置为低水平位,通知DCE停止传输数据。DTE(计算机)的缓冲区较大,通常都将RtsControl设置位ENABLE,即保持高水平位。
DTR/DSR:对于DTE来说,设置OutDsrFlow则DSR低水平位时停止输出,直至高水平位时恢复输出。设置DtrControl为HANDSHAKE则当DTR设置为高水平位时容许数据输入,当DTR为低水平位时阻止数据输入。DTE(计算机)的缓冲区较大,通常都将DtrControl设置位ENABLE,即保持高水平位。
XON/XOFF:对于DTE来说,设置OutX时,输出流在DTE收到XoffChar时停止,在收到XonChar时恢复。设置InX时,输入流在缓冲区空闲不足XoffLim时DTE发送XoffChar,通知DCE中止传输数据。当输入流达到缓冲区空闲超过XonLim时,DTE发送XonChar,通知DCE恢复传输数据。
三、编程模式:
在WIN32环境中,串口作为文件访问,但与其他文件不同,串口文件的操作是采用阻塞方式的,读写动作通常会在后台阻塞,用户可以通过响应串口事件,获知端口状态和控制读写动作。因此在WIN32环境中处理串口,应采用重叠I/0机制访问串口文件和在线程中完成读写操作,这样意味着当读写线程阻塞时,不会使主线程锁定而失去响应。
1、串口文件操作方式:根据如上要求,串口一般采用独占和重叠方式打开,如:CreateFile(_T("\\\\.\\COM1"),/*端口名称*/
GENERIC_READ|GENERIC_WRITE,/*文件可读写*/
0,/*独占方式*/
NULL,/*无权限属性*/
OPEN_EXISTING,/*端口必须存在*/
FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED,/*重叠的操作方式*/
NULL/*不支持临时文件*/)。
有效的串口文件打开后,可以进行重叠的读写操作,其中要使用一个重叠操作结构OVERLAPPED:
struct { DWORD Internal; /*内部使用*/
DWORD InternalHigh; /*内部使用*/
DWORD Offset; /*操作开始的文件位置(低位),串口文件不支持*/
DWORD OffsetHigh;/* 操作开始的文件位置(高位),串口文件不支持*/
HANDLE hEvent; /*异步事件句柄,重叠操作完成或中断时被激发*/
} OVERLAPPED;
写串口的方式如下:
WriteFile(hCom,/*串口文件句柄*/
(void*)data,/*数据指针*/
dwDataBytes,/*请求写的数据字节数*/
&dwOperaBytes,/*函数返回的已写的字节数,在重叠I/O中通常返回0*/
&ov/*重叠操作结构指针*/);
读串口的方式如下:
ReadFile(hCom,/*串口文件句柄*/
(void*)buf,/*缓冲区指针*/
dwDataBytes,/*请求读的数据字节数*/
&dwOperaBytes,/*函数返回的已读的字节数,在重叠I/O中通常返回0*/
&ov/*重叠操作结构指针*/);
重叠方式调用读写函数后即返回,程序稍后调用等待事件函数进入阻塞状态,直至异步事件被激发,调用方式如下:
WaitForSingleObject(hEvent,/*OVERLAPPED中异步事件句柄*/
dwTimeouts/*读写超时毫秒数*/)
读写超时设置可以由串口配置超时参数COMMTIMEOUTS获得,读超时数 =ReadTotalTimeoutMultiplier * 读字节数 + ReadTotalTimeoutConstant; 写超时数 =WriteTotalTimeoutMultiplier * 写字节数 + WriteTotalTimeoutConstant;
异步事件返回后,可以调用重叠I/O查询函数查看后台读写状况:
GetOverlappedResult(hCom, /*端口文件句柄*/
&ov, /*重叠结构指针*/
&dwOperaBytes, /*重叠操作完成的字节数*/
FALSE/*是否需要等待重叠操作完成*/);
以上时串口文件的操作方式,需要注意的是,这些操作除了打开文件外,其他都应当在某个读写线程中调用,让线程在后台阻塞,主线程保持响应。
2、端口事件侦听:WIN32提供串口事件查询函数用以查看端口触发的事件,端口可侦听事件一般有:
EV_BREAK :端口中断信号
EV_CTS :CTS信号改变
EV_DSR :DSR信号改变
EV_RXCHAR :收到一个或多个字符
EV_RXFLAG :收到特殊字符
EV_ERR :端口错误信号
EV_TXEMPTY:输出缓冲区数据发送完成
可以通过SetCommMask(hCom/*端口文件句柄*/,dwMask/*事件组合*/)来设置需要侦听的事件,然后应采用重叠模式调用查询事件函数:
WaitCommEvent(hCom, /*端口文件句柄*/
&dwMask,/*端口事件组合*/
&ov/*重叠I/O结构*/);
该函数在重叠I/0方式调用后即返回,侦听例程稍后调用WaitForSingleObject进入阻塞状态,OVERLAPPED中的异步事件被激发后返回,程序可以根据dwMask中返回的事件标志做进一步的处理,如:
switch(dwMask)
{
case EV_BREAK:
/*向主线程发送端口中断消息*/break;
case EV_CTS:
case EV_DSR:
/*向主线程发送端口状态消息*/break;
case EV_ERR:
/*向主线程发送端口错误消息*/break;
case EV_RXFLAG:
/*向主线程发送接收特殊字符消息,通知主线程读*/break;
case EV_RXCHAR:
/*向主线程发送接收字符消息,通知主线程读*/break;
case EV_TXEMPTY:
/*向主线程发送数据已发送消息*/break;
}
3、侦听、读写线程的处理模式:在串口编程模式中主线程启动时创建侦听线程,在主线程结束时终止侦听线程。主线程根据读写要求创建读写线程,并在线程结束后返回。在线程处理中重点要保护主线程中的临界资源的使用,如串口文件句柄、主线程的控制变量,主线程退出前应当通知工作线程并等待其终止。
工作线程启动需要一个传入参数用来访问主线程的资源,通常这样定义传入参数:
struct {
BOOL bActive; /*主线程活动标志,通常用于通知后台常驻线程(如侦听线程),主线程即将退出*/
HANDLE hCom; /*串口文件句柄*/
HANDLE evTerm; /*用于通知主线程,本线程已经终止*/
CRITICAL_SECTION cs; /*用于控制临界资源访问*/
BYTE* data; /*读线程的数据指针或写线程的缓冲区指针*/
DWORD dwQueryBytes; /*请求读写操作的字节数*/
DWORD dwResultBytes; /*用于返回操作完成后的实际字节数*/
DWORD dwTimeouts; /*阻塞超时毫秒数*/
int nResultCode; /*用于返回操作的状态码*/
}ThreadParam;
oyljerry 2005-07-07
  • 打赏
  • 举报
回复
看一下输出的命令字符格式是否正确
chqu18 2005-07-07
  • 打赏
  • 举报
回复
那不用Unicode 字符看看
Str= "Na\n";

tzh127 2005-07-07
  • 打赏
  • 举报
回复
我确定是这个命令,to xqk(夏乾坤) 那你是说我要把换行符去掉?并且把空格去掉吗?
xqk 2005-07-07
  • 打赏
  • 举报
回复
你确定Na为传感器提供的串口数据查询命令?

那么 (_T("Na\n") 转成的Unicode字符串为:

N a \n

因为unicode 是WORD型的
cryptonym 2005-07-07
  • 打赏
  • 举报
回复
简单的就用mscomm控件。
复杂点就用api中的readfile和writefile。

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧