虚拟串口模拟器和串口调试助手使用教程「建议收藏」

虚拟串口模拟器和串口调试助手使用教程「建议收藏」虚拟串口(虚拟COM端口),应该很多人都知道,也就是一种模拟物理串行接口的软件。它完全复制了硬件COM接口的功能,并且将被操作系统和串行应用程序识别为真实端口。以前的电脑,基本标配都包含一个串口。但现在的电脑,基本都没有配置串口了。如果要使用串口的功能,基本就要用一个USB转串口的硬件模块。现实生活中,虚拟串口用处很多。比如:你的应用程序检测串行输入数据的时候,方便调试。还比如:多个有应用程序之间使用串口通信。虚拟串口软件推荐:强大的虚拟串口软件串口调试助手软件有很多,随便选一个自己

大家好,又见面了,我是你们的朋友全栈君。

虚拟串口(虚拟 COM 端口),应该很多人都知道,也就是一种模拟物理串行接口的 软件 它完全复制了硬件 COM 接口的功能,并且将被操作系统和串行应用程序识别为真实端口。

以前的电脑,基本标配都包含一个串口。但现在的电脑,基本都没有配置串口了。如果要使用串口的功能,基本就要用一个USB转串口的硬件模块。

现实生活中,虚拟串口用处很多。比如:你的应用程序检测串行输入数据的时候,方便调试。还比如:多个有应用程序之间使用串口通信。

虚拟串口软件推荐:强大的虚拟串口软件


串口调试助手软件有很多,随便选一个自己习惯的即可。


演示一下串口模拟器和串口调试助手使用

打开VSPD,添加虚拟串口

在这里插入图片描述

打开串口调试助手,设置好必要的参数

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801141400770.png
https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801141420257.png

打开两个串口,在其中一个串口中发送区写入消息,点击发送,在另一个串口的接收区可以看到我们发送的消息

在这里插入图片描述

两个串口的连接示意图如下图所示

image-20210801143004531

数据传输路线有两条

  • 串口调试助手1–>COM1–>COM2–>串口调试助手2
  • 串口调试助手2–>COM2–>COM1–>串口调试助手1

在Windows下使用C语言调用串口,接收发送数据

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801144941433.png

C语言程序测试接收代码如下:

#include<stdio.h>
#include<windows.h>
 
int main()
{
	FILE *fp;
	if ((fp = fopen("com1", "r")) == NULL)
	{
		printf("cannot open com!\n");
	}
	else
		printf("open com successful!\n");
	char str;
	while (1)
	{
		fscanf(fp, "%c", &str);
		printf("%c ", str);
		Sleep(100);
	}
	return 0;
}

运行

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801150720719.png

因为这个程序打开的是COM1,因此我么在COM2的串口调试助手中,在发送区输入要发送的值,点击发送
在这里插入图片描述
这是可以在运行串口看到接收并且打印出我们发送的值

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801150945647.png

我们继续测试几次

image-20210801151033146

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210801151046652.png

C语言程序测试发送代码如下:

#include <Windows.h>
#include <stdio.h>
 
HANDLE hCom;
 
int main(void)
{
	hCom = CreateFile(TEXT("COM1"),//COM1口
		GENERIC_READ, //允许读
		0, //指定共享属性,由于串口不能共享,所以该参数必须为0
		NULL,
		OPEN_EXISTING, //打开而不是创建
 
		FILE_ATTRIBUTE_NORMAL, //属性描述,该值为FILE_FLAG_OVERLAPPED,表示使用异步I/O,该参数为0,表示同步I/O操作
		NULL);
 
	if (hCom == INVALID_HANDLE_VALUE)
	{
		printf("打开COM失败!\n");
		return FALSE;
	}
	else
	{
		printf("COM打开成功!\n");
	}
 
	SetupComm(hCom, 1024, 1024); //输入缓冲区和输出缓冲区的大小都是1024
 
	/*********************************超时设置**************************************/
	COMMTIMEOUTS TimeOuts;
	//设定读超时
	TimeOuts.ReadIntervalTimeout = MAXDWORD;//读间隔超时
	TimeOuts.ReadTotalTimeoutMultiplier = 0;//读时间系数
	TimeOuts.ReadTotalTimeoutConstant = 0;//读时间常量
	//设定写超时
	TimeOuts.WriteTotalTimeoutMultiplier = 1;//写时间系数
	TimeOuts.WriteTotalTimeoutConstant = 1;//写时间常量
	SetCommTimeouts(hCom, &TimeOuts); //设置超时
 
	/*****************************************配置串口***************************/
	DCB dcb;
	GetCommState(hCom, &dcb);
	dcb.BaudRate = 9600; //波特率为9600
	dcb.ByteSize = 8; //每个字节有8位
	dcb.Parity = NOPARITY; //无奇偶校验位
	dcb.StopBits = ONESTOPBIT; //一个停止位
	SetCommState(hCom, &dcb);
 
	DWORD wCount;//实际读取的字节数
	bool bReadStat;
 
	char str[2] = { 0 };
 
	while (1)
	{
		int i;
    	unsigned char sendData[256] = {0};//写入串口缓存区的数组
    	for(i=0; i<16; i++)
    	{
        	sendData[i] = i;
    	}

    	DWORD dwWriteLen = 0;
    	if(!WriteFile(hCom, sendData, 16, &dwWriteLen, NULL))
    	{
        	printf("串口发送数据失败!\n");
    	}
		Sleep(1000);
	}
 
	CloseHandle(hCom);
}

也可以使用下面这段代码

#include<stdio.h>
#include<windows.h>
 
int main()
{
	FILE *fp;
	if ((fp = fopen("com1", "r")) == NULL)
	{
		printf("cannot open com!\n");
	}
	else
		printf("open com successful!\n");
		
	char str = 'x';
 
	while (1)
	{
		fprintf(fp, "%s", &str);
		Sleep(1000);
	}
	return 0;
}

不过不知道为什么,这两段代码都可以正常运行,但是COM2的串口调试助手那接收不到数据。
最近发现了是哪里出了问题,串口参数不一致导致的问题。
只需要将代码改成如下

#include <Windows.h>
#include <stdio.h>
 
HANDLE hCom;
 
int main(void)
{
	hCom = CreateFile(TEXT("COM1"),//COM1口
		GENERIC_READ | GENERIC_WRITE, //允许读和写 
		0, //指定共享属性,由于串口不能共享,所以该参数必须为0
		NULL,
		OPEN_EXISTING, //打开而不是创建
 
		FILE_ATTRIBUTE_NORMAL, //属性描述,该值为FILE_FLAG_OVERLAPPED,表示使用异步I/O,该参数为0,表示同步I/O操作
		NULL);
 
	if (hCom == INVALID_HANDLE_VALUE)
	{
		printf("打开COM失败!\n");
		return FALSE;
	}
	else
	{
		printf("COM打开成功!\n");
	}
 
	SetupComm(hCom, 1024, 1024); //输入缓冲区和输出缓冲区的大小都是1024
 
	/*********************************超时设置**************************************/
	COMMTIMEOUTS TimeOuts;
	//设定读超时
	TimeOuts.ReadIntervalTimeout = MAXDWORD;//读间隔超时
	TimeOuts.ReadTotalTimeoutMultiplier = 0;//读时间系数
	TimeOuts.ReadTotalTimeoutConstant = 0;//读时间常量
	//设定写超时
	TimeOuts.WriteTotalTimeoutMultiplier = 1;//写时间系数
	TimeOuts.WriteTotalTimeoutConstant = 1;//写时间常量
	SetCommTimeouts(hCom, &TimeOuts); //设置超时
 
	/*****************************************配置串口***************************/
	DCB dcb;
	GetCommState(hCom, &dcb);
	dcb.BaudRate = 115200; //波特率为115200
	dcb.ByteSize = 8; //每个字节有8位
	dcb.Parity = NOPARITY; //无奇偶校验位
	dcb.StopBits = ONESTOPBIT; //一个停止位
	SetCommState(hCom, &dcb);
 
	DWORD wCount;//实际读取的字节数
	bool bReadStat;
 
	char str[2] = { 0 };
 
	while (1)
	{
		int i;
    	unsigned char sendData[256] = {0};//写入串口缓存区的数组
    	for(i=0; i<16; i++)
    	{
        	sendData[i] = i;
    	}

    	DWORD dwWriteLen = 0;
    	if(!WriteFile(hCom, sendData, 16, &dwWriteLen, NULL))
    	{
        	printf("串口发送数据失败!\n");
    	}
		Sleep(1000);
	}
 
	CloseHandle(hCom);
}

运行之后,发现在串口2的调试助手处,显示的接收数据在增加,

在这里插入图片描述
在这里插入图片描述

但是却不会在界面上显示出来,这个不知道是啥原因。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131062.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PL/SQL 入门学习(一)

    PL/SQL 入门学习(一)在学校的时候虽说上过PL/SQL这门课,然并卵,只恨当时啊!工作关系,需要用到Oracle存储过程。我就简单看了一些教程,特此记录一下。首先,先介绍一下PL/SQL是什么?PL/SQL是是由甲骨文公司在90年代初开发,以提高SQL的功能。PL/SQL是嵌入在Oracle数据库中的编程语言之一。PL/SQL是Oracle数据库对SQL语句的扩展。在普通SQL语句的使用上增加了编程语言的特点…

    2022年8月20日
    5
  • 控制指定的页面刷新

    控制指定的页面刷新当我们在某个页面进行操作之后 我们希望指定的那个页面能刷新 以小程序为例子我们需要设置一个全局的变量 作为刷新的列表 存储指定刷新的页面的路由 然后定义两个全局的函数 setReflash 和 execReflash setReflash 将当前页面的上一頁的路由或者指定的多个路由添加到刷新列表中 设置返回上一页要刷新提示 callbackfunc 要回调执行的函数

    2025年7月25日
    5
  • 线段树入门 敌兵布阵

    线段树入门 敌兵布阵

    2021年9月27日
    52
  • aop实现原理面试_aop ioc 面试怎么回答

    aop实现原理面试_aop ioc 面试怎么回答作用——用于处理系统中分布的各个模块的横切关注点(如:事务管理、日志、缓存等),是使用动态代理实现,在内存中临时为增强某个方法生成一个AOP对象,该对象含有目标对象的所有方法,在特定的切入点做了增强处理,并回调原来的方法。P:咋眼一看,不能直接理解很正常。动态代理的实现——主要分两种方式实现1、JDK动态代理原理说明——JDK动态管理通过反射接收被代理的类,该代理的类必须实现接口,核心是InvocationHandler和Proxy类。2、Cglib动态代理原理说明——Cglib通过.

    2025年11月30日
    6
  • 什么是 Hook 技术

    什么是 Hook 技术一、什么是Hook技术  Hook技术又叫做钩子函数,在系统没有调用该函数之前,钩子程序就先捕获该消息,钩子函数先得到控制权,这时钩子函数既可以加工处理(改变)该函数的执行行为,还可以强制结束消息的传递。简单来说,就是把系统的程序拉出来变成我们自己执行代码片段。  要实现钩子函数,有两个步骤:  1.利用系统内部提供的接口,通过实现该接口,然后注入进系统(特定场景下使用)  2.动态代理(使用所有场景)二、Hook技术实现的步骤  Hook技术实现的步骤也分为两步  1.找到ho

    2022年5月13日
    41
  • vscode golang环境搭建「建议收藏」

    vscode golang环境搭建「建议收藏」vscode安装百度下载可执行文件,一路nextgolang安装下载地址为:https://golang.google.cn/dl/如果是linux环境,解压到某个目录。然后配置/etc/profile设置相关环境变量如果是windows环境,下载https://dl.google.com/go/go1.13.5.windows-amd64.msi,然后设置环境变量。环境变量为:G…

    2022年10月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号