求教一个关于串口通信的一个问题(急!!!!!!!)

zeroyeah 2001-12-03 09:22:09
有一基于文档的串口通信程序,原理为串口2(COM2)产生随机数每隔1秒向串口1(COM1)发送的NEMA格式的报文,其中一段源码如下:
void CSCPortTestView::OnTimer(UINT nIDEvent)
{
// TODO: Add your message handler code here and/or call default
int randdata=rand()%9000; //产生9000以内的随机数
CString strSendData;
strSendData.Format("%04d",randdata);
SendString(strSendData, 2); //串口2发送数据;
CView::OnTimer(nIDEvent);
}
现我希望以用户的输入(可以是汉字、英文字符或数字,用的是ceditview类)来取代随机数,但不知如何生成校验码,附校验码生成函数SendString

void CSCPortTestView::SendString(CString &str, int Port)
{
char checksum=0,cr=CR,lf=LF;
char c1,c2;
for(int i=0;i<str.GetLength();i++)
checksum = checksum^str[i];
c2=checksum & 0x0f; c1=((checksum >> 4) & 0x0f);
if (c1 < 10) c1+= '0'; else c1 += 'A' - 10;
if (c2 < 10) c2+= '0'; else c2 += 'A' - 10;
CString str1;
str1='$'+str+"*"+c1+c2+cr+lf;
m_ComPort[Port-1].WriteToPort((LPCTSTR)str1);
}
...全文
161 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaoxiaohan 2001-12-18
  • 打赏
  • 举报
回复
用C语言编写简单的接口程序
在通信中,为了保证运行安全可靠,标准的串行口必须具有许多握手信号和状态信息。这是因为通信的各个计算机CPU速度不一样(这会导致?错帧敚?以及发送机发送数据速度比接收机接 收速度快(这会导致?过冲敚?为解决这个问题,我们采用一个简单的握手信号,即发送机每次仅发送半个字节(低4位)的数据,而另外半个字节(高4位)则用来传送信息。我们可以对信息位(高4位)进行如下简单的编码:
0H: 发送的是新的半个字节数据
1H: 重新发送上次传送错误的数据
2H: 文件名结束
3H: 文件结束
这样,每当发送机发送一个字节以后,就等待接受机发回送信号,这回送信号就是发送机发送过来的那个字节。发送机接收到回送信号后,把它与刚发送的字节相比较,如果相同,就发送新的半个字节,否则就重新发送。新数据与旧数据通过信息位来区分。下面就是我用C语言编写控制串行口的程序。以一个发送文件的程序为例,介绍一下用C语言实现对接口的 控制。
源 程 序 为:
#include “dos.h"
#include “stdlib.h"
#include “stdio.h"

#define PORT 0

void SendFile(char fname);
/ * 发 送 文 件 */
void Send(int s);
/ * 发 送 一 个 字 节 */
void SendFileName(char fname);
/ * 发 送 文 件 名 */
void ReceiveFile();
/ * 接 收 文 件 */
void GetFileName(char f);
/ * 接 收 文 件 名 */
void InitPort(int port,unsigned char para);
/ * 初 始 化 端 口 */
void SendPort(int port,char c);
/ * 端 口 发 送 */
int ReadPort(int port);
/ * 读 端 口 字 节 */
int CheckState(int port);
/ * 检 查 端 口 状 态 */
int Receive(int port,int G);
/ * 接 收 一 个 字 节 */

main(argc,argv)
int argc;
char *argv[];
{
if(argc<2){
printf(“Please input R(receive)
or S(sent) parametre:");
exit(1);
}
InitPort(PORT,231);
if(argv[1]==‘S')
/ * 检 查 选 择 的 有 效 性 */
SendFile(argv[2]);
else if(argv[1]==‘R')
ReceiveFile();
else{
printf(“Error parament.Please input again.");
exit(1);
}
}

void SendFile(fname)
char *fname;
{
FILE *fp;
int ch,s;
if(!(fp=fopen(fname,“rb"))){
printf(“Can't open the file.\n");
exit(1);
}
SendFileName(fname);
do{
ch=(int)getc(fp);
if(ferror(fp)){
printf(“Error reading file.\n");
break;
}
s=ch %16;
/ * 取 文 件 中 一 个 字 节 的 低4 位 */
Send(s);
s=ch/16;
/ * 取 文 件 中 一 个 字 节 的 高4 位 */
Send(s);
}while(!feof(fp));
s=46; / * 发 送 文 件 结 束 信 息 */
Send(s);
Send(s);
fclose(fp);
}

void Send(s)
int s;
{
int G;
SendPort(PORT,s);
G=ReadPort(PORT); / * 等 待 握 手 信 号 */
if(s!=G)
s=s +16;
do{
SendPort(PORT,s);
G=ReadPort(PORT); / * 等 待 握 手 信 号 */
}while(s!=G);
}

void SendFileName(fname)
char *fname;
{
int s,ch;
printf(“Now transmit the file.Please wait...");
while( *fname){
ch=(int)fname + +;
s=ch %16;
/ * 取 文 件 名 中 一 个 字 节 的 低4 位 */
Send(s);
s=ch/16;
Send(s);
/ * 取 文 件 名 中 一 个 字 节 的 低4 位 */
}
s=32;/ * 发 送 文 件 名 结 束 标 志 */
Send(s);
Send(s);
}

void ReceiveFile(){
FILE *fp;
char ch;
int G1,G2,G3;
char fname[15];
GetFileName(fname);
printf(“Receiving file %s.\n",fname);
remove(fname);
if(!(fp=fopen(fname,“wb"))){
printf(“Can't open output file.\n");
exit(1);
}

/*循环为检测每次接受的数据是否为新数据,如果不是,则用此次接收的数据覆盖上次接收的数据*/

G1=ReadPort(PORT);
G2=Receive(PORT, &G1);
do{
G3=Receive(PORT, &G2);
ch=(char)(G1 %16 +G2 *16);
/ * 恢 复 分 开 的 数 据,
组 合 高4 位 和 低4 位 */
putc(ch,fp);
if(ferror(fp)){
printf(“\nError writing file.");
exit(1);
}
G2=Receive(PORT, &G3);
G1=G3;
}while(G1/16!=48);
printf(“\nTransmit finished.");
fclose(fp);
}

int Receive(port,G)
int port, *G;
{
int GM;
SendPort(port, *G);
GM=ReadPort(port);
if(GM/16==0)
return GM;
else if(GM/16==1){
do{
*G=GM;
SendPort(port,GM);
GM=ReadPort(port);
}while(GM/16==1);
}
return GM;
}

void GetFileName(f)
char *f;
{
int G1,G2,G3;
char ch;
G1=ReadPort(PORT);
G2=ReadPort(PORT);
do{
G3=Receive(PORT, &G3);
ch=(char)(G1 %16 +G2/16);
*f=ch;
*f + +;
G2=Receive(PORT, &G3);
G1=G3;
}while(G1/16!=32);
printf(“File name transmit finished.\n");
}

void InitPort(port,para)
int port;
unsigned char para;
{
union REGS reg;
reg.x.dx=port;
reg.h.ah=0;
reg.h.al=para;
int86(0x14, &reg, &reg);
}

void SendPort(port,c)
int port;
char c;
{
union REGS reg;
reg.x.dx=port;
reg.h.al=c;
reg.h.ah=1;
int86(0x14, &reg, &reg);
if(reg.h.ah &128){
printf(“\nSend mistakes!");
exit(1);
}
}

int ReadPort(port)
int port;
{
union REGS reg;
while(!(CheckState(port) &256)){
if(kbhit()){ / * 如 端 口 长 期
无 数 据 可 人 为 终 止 等 待 */
printf(“Press any key to exit.");
getch();
exit(1);
}
}
reg.x.dx=port;
reg.h.ah=2;
int86(0x14, &reg, &reg);
if(reg.h.ah &128){
printf(“\nRead mistake!");
exit(1);
}
return reg.h.al;
}

int CheckState(port)
int port;
{
union REGS reg;
reg.x.dx=port;
reg.h.ah=3;
int86(0x14, &reg, &reg);
return reg.x.ax;
}
zeroyeah 2001-12-04
  • 打赏
  • 举报
回复
doomleo(leo)你到底知道我在是说什么吗?
zf925 2001-12-04
  • 打赏
  • 举报
回复
如果是格式校验,那要通过协议来确定,你是不是应该多了解协议啊?
zf925 2001-12-04
  • 打赏
  • 举报
回复
串口设定中不是有奇偶校验吗?
dcb.Parity=NOPARITY; or dcb.Parity=EVENPARITY;
不就行了吗?
cafecai 2001-12-03
  • 打赏
  • 举报
回复
我没看明白
Leo 2001-12-03
  • 打赏
  • 举报
回复
void CSCPortTestView::SendString(CString &str, int Port)
{
char checksum=0,cr=CR,lf=LF;
char c1,c2;
for(int i=0;i<str.GetLength();i++)
checksum = checksum^str[i];
for(int i=0;i<str.GetLength();i++)
checksum = checksum^str[i];//与字符串的每一个字符相异或
c2=checksum & 0x0f; c1=((checksum >> 4) & 0x0f);//将校验码转为ASC码
if (c1 < 10) c1+= '0'; else c1 += 'A' - 10;
if (c2 < 10) c2+= '0'; else c2 += 'A' - 10;
CString str1;
str1='$'+str+"*"+c1+c2+cr+lf;
m_ComPort[Port-1].WriteToPort((LPCTSTR)str1);
}
就这么简单!
zeroyeah 2001-12-03
  • 打赏
  • 举报
回复
可我还是不懂呀!!?
zeroyeah 2001-12-03
  • 打赏
  • 举报
回复
很简单嘛.看看书就行啦!笨!!
zeroyeah 2001-12-03
  • 打赏
  • 举报
回复
大家快来帮帮我啊!!!!!!!!!!!!!!!!!!!!!!1

16,548

社区成员

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

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

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