大致过程就是
配置串口通信,包括串口号、波特率、校验位、停止位这些信息;
打开串口,和打开文件一样,在Linux下是这样,Windows下没试过,估计也差不多;
发送数据,即写串口,就跟写文件类似;
读取串口,用read就行。
具体的函数和配置参数可以参考一些别人的代码。
试试下列程序,这时用中断发送的。
#include<reg51h>
#define uchar unsigned char
uchar txt[] = "hello";
uchar i = 0;
void main(void)
{
PCON = 0X00;
SCON = 0X50;
TMOD = 0X20;
TH1 = 0XFD;
TL1 = 0XFD;
TR1 = 1;
EA = 1;
ES = 1;
TI = 1;
while(1) {
if(i == 6) {
i = 0;
TI = 1;
}
}
}
void uart() interrupt 4
{
if(RI == 1) RI = 0;
if(TI == 1) {SBUF = txt[i++]; TI = 0;}
}
本程序,可以用串口助手接收。收到的是:hellohellohellohellohello
添加一个MSComm控件,办法是,点菜单里的工程-部件,找到Microsoft Comm Control 60,打上对勾,然后确定就可以在旁边的部件栏里看到一个电话的标识的控件,就是MSComm,就可以用它来读写串口
以下是一个示例代码
Private Sub Form_Load ()
' 保存输入子串的缓冲区
Dim Instring As String
' 使用 COM1。
MSComm1CommPort = 1
' 9600 波特,无奇偶校验,8 位数据,一个停止位。
MSComm1Settings = "9600,N,8,1"
' 当输入占用时,
' 告诉控件读入整个缓冲区。
MSComm1InputLen = 0
' 打开端口。
MSComm1PortOpen = True
' 将 attention 命令送到调制解调器。
MSComm1Output = "ATV1Q0" & Chr$(13) ' 确保
' 调制解调器以"OK"响应。
' 等待数据返回到串行端口。
Do
DoEvents
Buffer$ = Buffer$ & MSComm1Input
Loop Until InStr(Buffer$, "OK" & vbCRLF)
' 从串行端口读 "OK" 响应。
' 关闭串行端口。
MSComm1PortOpen = False
End Sub
C#串口 *** 作之读取串口数据:
try
{
axMSComm2CommPort = 1i;
axMSComm2InputMode =
MSCommLibInputModeConstantscomInputModeBinary;
//用于设置或返回传输数据的类型,
//此例程是通过Input属性以二进制方式检取回数据
axMSComm2PortOpen = true;
//打开端口
axMSComm2InBufferCount = 0;
//用于返回输入缓冲区内的等待读取得字节个数
}
catch (Exception e)
{
MessageBoxShow(eToString());
}
在axMSComm的OnComm事件里写:
private void axMSComm2_OnComm(object sender, EventArgs e)
{
switch (axMSComm2CommEvent) //查询CommEvent属性
{
case (short)(MSCommLibOnCommConstantscomEvReceive):
//当接收缓冲区内字符数达到RThreshold值,
//进入CommData()子程序
CommData(); //接收缓冲区内数据
break;
}
}
private void CommData() //接收数据
{
int BufferDataNumStart = 0;
//定义第一次查询缓冲区内数据个数
int BufferDataNumEnd = 0;
//定义最后一次查询缓冲区内数据个数
byte[] CommBufferData = new byte[1024];
byte[] ComByte = new byte[8];
BufferDataNumStart = axMSComm2InBufferCount; ;
//将缓冲区内等待读取的字节个数赋给BufferDataNumStart
if (BufferDataNumStart == 0) return;
//如果缓冲区为空,说明还没有数据传来,
//则返回;若不为空,进入下面的循环
//读取缓冲区内全部内容
axMSComm2InputLen = 0;
while (true)
{
SystemThreadingThreadSleep(50);
//延时,以确保数据完全接收
BufferDataNumEnd = axMSComm2InBufferCount;
//再次读取缓冲区内字节个数
if (BufferDataNumStart == BufferDataNumEnd) break;
//如果BufferDataNumStart==BufferDataNumEnd,
//说明本帧数据已经读完,退出循环
BufferDataNumStart = BufferDataNumEnd;
//否则,将BufferDataNumEnd赋给BufferDataNumStart,
//并继续循环,直到完全接收
}
object objIn;
objIn = axMSComm2Input;
//这里注意MSCommInput返回的是一个object的类型,
//所以必须使用显式的类型转换
CommBufferData = (byte[])objIn;
//CommBufferData为串口缓冲区内所有数据
//存取最后一次接收到的缓冲区的数据,
//存储部分时作为后期数据处理所用,
//以便于程序员分析数据。使用StreamWriter,
//需在添加命名控件using SystemIO;
//将上次未处理的数据和本次存储数据在ReceivedData相连,
//此部分是防止发送过来的数据本身就不完整,
//以至于数据处理不能进行完全,故保留并与新接收的数据相连
for (int i = 0; i < BufferDataNumEnd; i++)
{
ReceiveDataNum++;
UnsettledDataNum++;
ReceivedData[ReceiveDataNum - 1] = CommBufferData[i];
}
//进入数据处理字程序
}
private void DealData() //数据处理
{
for (int i = 0; i < ReceivedDataLength - 7; i++)
{
if (ReceivedData[i] ==
0xff && ReceivedData[i + 1] == 0x04)判断通讯头
{
zhou++;
INTzhouzhong[zhou] =
intParse(ReceivedData[i + 4]ToString("X")) 10000 +
intParse(ReceivedData[i + 3]ToString("X")) 100 +
intParse(ReceivedData[i + 2]ToString("X"));
}
}
ReceiveDataNum = 0;
UnsettledDataNum = 0;
}
有串口控件MSComm控件
MSComm 控件示例
下面这个简单的例子演示了用调制解调器进行基本的串行通讯:
Private Sub Form_Load ()
' 保存输入子串的缓冲区
Dim Instring As String
' 使用 COM1。
MSComm1CommPort = 1
' 9600 波特,无奇偶校验,8 位数据,一个停止位。
MSComm1Settings = "9600,N,8,1"
' 当输入占用时,
' 告诉控件读入整个缓冲区。
MSComm1InputLen = 0
' 打开端口。
MSComm1PortOpen = True
' 将 attention 命令送到调制解调器。
' Chr$函数:返回 String,其中包含有与指定的字符代码相关的字符 。
MSComm1Output = "ATV1Q0" & Chr$(13) ' 确保
' 调制解调器以"OK"响应。
' 等待数据返回到串行端口。
Do
DoEvents
Buffer$ = Buffer$ & MSComm1Input
Loop Until InStr(Buffer$, "OK" & vbCRLF)
' 从串行端口读 "OK" 响应。
' 关闭串行端口。
MSComm1PortOpen = False
End Sub
c或vb中有mscomm控件很好用,我常用,以下是我用delphi写的
with mscomm1 do begin
commport:=1; //端口号
settings:=9600,n,8,1; //端口设置
InputMode:=0; //设置或返回Input属性取回的数据的类型 0:文本 1:二进制
RThreshold:=1; //每次接收到字符即产生OnComm事件
SThreshold:=0; //传输缓冲区允许最小字符数
InBufferCount:=0; //清空接收缓冲区内容
InputLen:=0; //为0时 Input一次读取整个缓冲区内容
DTREnable:=true; //数据终端准备好
RTSEnable:=true; //发送请求
end;
mscomm1Output:=edit1text;//发送
str:=mscomm1input; //接收
以上就是关于如何用C语言写一个读、写串口的程序全部的内容,包括:如何用C语言写一个读、写串口的程序、简单51单片机串口程序、知道通讯协议如何开发串口程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)