LYL程序员小白的理解之简单易懂的Arduino的串口通讯

自白

我是一名大四应届生,第一次写这个博客,可能很多地方写的不是那么好,也有可能有些理解不对,所以请多谅解!写这篇文章是因为我发现Arduino的串口通讯相关的文章对很多小白不太友好,我这篇文章是我自己实践过后得出的简单易懂的教程,之后会继续推出Arduino串口通讯控制外设的文章!

启动串口通讯

Serial.begin()

描述:
开启串口,通常置于setup()函数中。

原型:
Serial.begin(speed)
Serial.begin(speed, config)

参数:
speed:波特率,一般取值9600,115200等。
config:设置数据位、校验位和停止位。默认SERIAL_8N1表示8个数据位,无校验位,1个停止位。

返回值:
无。

void setup() {   
	Serial.begin(9600); //启动串行通讯
}

判断串口接收数据的语句

Serial.available()

描述:
判断串口缓冲区的状态,返回从串口缓冲区读取的字节数。

原型:
Serial.available()

参数:
无。

返回值:
可读取的字节数。

Serial.readBytesUntil()

描述:
从串口读取指定长度的字符到缓存数组。
当函数读取到终止字符后,会立即停止函数执行。

原型:
Serial.readBytesUntil(character, buffer, length)

参数:
character:终止字符。
buffer:缓存变量。
length:设定的读取长度。

返回值:
返回存入缓存的字符数。

实践

一个三位数整数

假如我们要从串口接收一个三位数的整数并且通过回车符就能实现接收完毕
首先我们需要准备三个参数变量的声明

int value = 0; 
char input[6]; 
char nextinput = '\n';  

然后我们需要限制在串口缓存区必须有数据,不然一直执行空语句

while(Serial.available()<=0) {}

最后我们需要判断在当串口缓存区有数据时则开始执行我们的接收语句

if(Serial.available()>0) { 
   Serial.readBytesUntil(nextinput,input,4);
   value = atoi(input); //强制转换字符串数组input为int型变量value
}

三个三位数整数

假如我们要从串口接收三个三位数的整数并且通过回车符就能实现接收完毕
首先我们需要准备四个参数变量的声明

int value[3]; 
char input1[6]; 
char input2[6]; 
char input3[6]; 
char blanket = ' ';
char nextinput = '\n';  

然后我们需要限制在串口缓存区必须有数据,不然一直执行空语句

while(Serial.available()<=0) {}

最后我们需要判断在当串口缓存区有数据时则开始执行我们的接收语句

if(Serial.available()>0) { 
   Serial.readBytesUntil(blanket,input1,4);
   Serial.readBytesUntil(blanket,input2,4);
   Serial.readBytesUntil(nextinput,input3,4);
   value[0] = atoi(input1); //强制转换
   value[1] = atoi(input2); //强制转换
   value[2] = atoi(input3); //强制转换
}

文章中有些语句的解释用到原作者的一篇文章:
Arduino基础入门篇23—串口通讯.

还有Arduino官网串口使用指南
Arduino官网串口使用指南.

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
写技术文档是程序员工作中非常重要的一部分,下面是一些建议来帮助你写技术文档: 1.明确目标受众:确定你的文档是面向其他开发人员、经理、客户还是非技术人员。这有助于你选择合适的语言和术语,并确保你的文档能够满足读者的需求。 2.使用清晰简洁的语言:避免使用过于复杂的术语和缩写,尽量使用通俗易懂的语言来解释技术概念。如果必须使用特定术语,确保在文档中提供清晰的解释和定义。 3.结构化和组织良好:将文档分成几个部分,例如介绍、使用指南、API文档等。使用标题、段落和列表来组织内容,以便读者可以轻松地找到所需信息。 4.提供示例代码和截图:在文档中提供具体的示例代码和截图,这有助于读者理解技术概念和步骤。确保示例代码准确、可运行,并附带适当的注释。 5.使用图表和图像:使用图表和图像来说明复杂的流程、架构或数据关系。这些图像可以帮助读者更好地理解和记忆文档中的信息。 6.更新和维护:技术文档应该与软件的版本保持同步,并定期进行更新和维护。确保删除或更新过时的信息,并添加新的功能和变更。 7.注重用户反馈:接受用户的反馈和建议,并根据需要对文档进行改进。这有助于提高文档的质量和可理解性。 最后,记住写技术文档是一项技能,需要不断的实践和改进。随着经验的积累,你会变得更加熟练并能够编写出高质量的技术文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值