1.配置串口通信数据位、校验位、停止位
通常我们使用Serial.begin(speed)来完成串口的初始化,这种方式,只能配置串口的波特率。
而使用Serial.begin(speed, config)可以配置数据位、校验位、停止位等。
例如Serial.begin(9600,SERIAL_8E2)是将串口波特率设为9600,数据位8,偶校验,停止位2。
config可用配置如下:

config可选配置 数据位 校验位 停止位   config可选配置 数据位 校验位 停止位
SERIAL_5N1 5 1   SERIAL_5E2 5 2
SERIAL_6N1 6 1   SERIAL_6E2 6 2
SERIAL_7N1 7 1   SERIAL_7E2 7 2
SERIAL_8N1 8 1   SERIAL_8E2 8 2
SERIAL_5N2 5 2   SERIAL_5O1 5 1
SERIAL_6N2 6 2   SERIAL_6O1 6 1
SERIAL_7N2 7 2   SERIAL_7O1 7 1
SERIAL_8N2 8 2   SERIAL_8O1 8 1
SERIAL_5E1 5 1   SERIAL_5O2 5 2
SERIAL_6E1 6 1   SERIAL_6O2 6 2
SERIAL_7E1 7 1   SERIAL_7O2 7 2
SERIAL_8E1 8 1   SERIAL_8O2 8 2

2. if (Serial)的用法
当串口被打开时,Serial的值为真。串口被关闭时Serial的值为假。
比较囧的是,这个方法只适用于Leonardo和micro的Serial,也就是说连接连接到电脑USB的那个模拟串口。
例如以下程序,当你没有使用串口监视器打开串口时,程序就会一直循环运行while (!Serial) {;} ,当你打开串口监视器,程序会退出while循环,开始loop中的程序。

[C++] 纯文本查看 复制代码
1
2
3
4
5
6
7
8
void setup() {
  Serial.begin(9600);
  while (!Serial) {;}
}
 
void loop() {
 
}

3.read和peek输入方式的差异
串口接收到的数据都会暂时存放在接收缓冲区中,使用read()与peek()都是从接收缓冲区中读取数据。不同的是,使用read()读取数据后,会将该数据从接收缓冲区移除;而使用peek()读取时,不会移除接收缓冲区中的数据。
你可以使用以下程序,观察其运行结果:

[C++] 纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
char col;
void setup() {
  Serial.begin(9600);
}
 
void loop() {
  while(Serial.available()>0){
    col=Serial.read();
    Serial.print("Read: ");
    Serial.println(col);
    delay(1000);
  }
}
[C++] 纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
char col;
void setup() {
  Serial.begin(9600);
}
 
void loop() {
  while(Serial.available()>0){
    col=Serial.peek();
    Serial.print("Read: ");
    Serial.println(col);
    delay(1000);
  }
}

4. 串口读入int型数据
实际上是串口读入字符串,再转换为int型数据。

[C++] 纯文本查看 复制代码
1
2
3
4
5
6
7
8
9
while (Serial.available() > 0) {
    int inChar = Serial.read();
    if (isDigit(inChar))
{
inString += (char)inChar;
}
i=inString.toInt();
}
}

5.输出不同进制的文本
我们可以是用 Serial.print(val, format)的形式输出不同进制的文本
参数val 是需要输出的数据
参数format 是需要输出的进制形式,你可以使用如下参数:
BIN(二进制)
DEC(十进制)
OCT(八进制)
HEX(十六进制)
例如,使用Serial.print(123,BIN),你可以在串口调试器上看到1111011
使用Serial.print(123,HEX),你可以在串口调试器上看到7B

6.Arduino MEGA\Arduino DUE上其他串口用法
serial1\serial2\serial3
和serial用法一样
比如serial3.begin(9600);

6.修改串口缓冲区大小
Arduino串口缓冲区默认为64字节,如果你单次传输的数据较多可以将
arduino-1.0.5-r2\hardware\arduino\cores\arduino\HardwareSerial.cpp中的
#define SERIAL_BUFFER_SIZE 64
修改为
#define SERIAL_BUFFER_SIZE 128
这样就有128字节的缓冲区了

Arduino串口的一些高级用法的更多相关文章

  1. Arduino 串口的一些高级用法

    来源: 1.配置串口通信数据位.校验位.停止位 通常我们使用Serial.begin(speed)来完成串口的初始化,这种方式,只能配置串口的波特率. 而使用Serial.begin(speed, c ...

  2. Arduino - 串口操作函数与示例代码大全

    来源:https://blog.csdn.net/iracer/article/details/50334041 Arduino - 串口操作函数与示例代码大全 本文总结了Arduino常用串口操作函 ...

  3. Visual Studio 宏的高级用法

    因为自 Visual Studio 2012 开始,微软已经取消了对宏的支持,所以本篇文章所述内容只适用于 Visual Studio 2010 或更早期版本的 VS. 在上一篇中,我已经介绍了如何编 ...

  4. SolrNet高级用法(分页、Facet查询、任意分组)

    前言 如果你在系统中用到了Solr的话,那么肯定会碰到从Solr中反推数据的需求,基于数据库数据生产索引后,那么Solr索引的数据相对准确,在电商需求中经常会碰到菜单.导航分类(比如电脑.PC的话会有 ...

  5. sqlalchemy(二)高级用法

    sqlalchemy(二)高级用法 本文将介绍sqlalchemy的高级用法. 外键以及relationship 首先创建数据库,在这里一个user对应多个address,因此需要在address上增 ...

  6. Solr学习总结(六)SolrNet的高级用法(复杂查询,分页,高亮,Facet查询)

    上一篇,讲到了SolrNet的基本用法及CURD,这个算是SolrNet 的入门知识介绍吧,昨天写完之后,有朋友评论说,这些感觉都被写烂了.没错,这些基本的用法,在网上百度,资料肯定一大堆,有一些写的 ...

  7. 再谈Newtonsoft.Json高级用法

    上一篇Newtonsoft.Json高级用法发布以后收到挺多回复的,本篇将分享几点挺有用的知识点和最近项目中用到的一个新点进行说明,做为对上篇文章的补充. 阅读目录 动态改变属性序列化名称 枚举值序列 ...

  8. Jquery remove 高级用法

    Jquery remove 高级用法 html 代码 <div class="file-image">abc1111</div><div class= ...

  9. Newtonsoft.Json高级用法(转)

    手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...

随机推荐

  1. SQLyog连接报错 Error No.2058 Plugin caching_sha2_password could not be loaded

    参考链接:https://blog.csdn.net/qq_22766431/article/details/80628583 win10系统更新安装Mysql8.0,连接SQLyog的时候出现下面错 ...

  2. mongodb - 关联字段

    1,博客表结构  Blog.js var mongoose = require('mongoose') mongoose.connect('mongodb://localhost/test',{ us ...

  3. php的排序算法

    *对于算法来说,对于每个小伙伴来说都是比较头疼的,但是,为什么要学习算法? 算法是基础,算法能够提升智力,我想这两点就值得我们花时间去学习了.不要放弃,实在不会,先死记硬背下来,以后慢慢理解,一下是我 ...

  4. CPU各个具体的指标含义

    CPU各个具体的指标含义解释如下: ①CPU(监测到的master主机上的CPU使用情况) 从图中看出,一共有五个关于CPU的指标.分别如下: 1. User User表示:CPU一共花了多少比例的时 ...

  5. 字符设备驱动之LED驱动

    实现 ①编写驱动框架 ②编写硬件实现代码 (在Linux系统下操作硬件,需要操作虚拟地址,因此需要先把物理地址转换为虚拟地址 ioremap()) 如何实现单个灯的操作: 实现方法之一--操作次设备号 ...

  6. HihoCoder第十四周:无间道之并查集

    #1066 : 无间道之并查集 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 这天天气晴朗.阳光明媚.鸟语花香,空气中弥漫着春天的气息--额,说远了,总之,小Hi和小H ...

  7. 【docker】docker持续集成CI/持续部署CD

    持续集成(CI) 持续集成(Continuous integration)是一种流行的软件开发实践.集成是指开发将自己本地的代码提交到git等远端仓库上,那么持续集成就是每天多次提交,提早提交代码. ...

  8. 虚拟机安装centos6.5出现Error processing drive:pci-0000:00:10-scsi-0:0:0:0问题

    vmware安装linux系统出现Error processing drive:pci-0000:00:10-scsi-0:0:0:0问题 问题出现原因:我给虚拟机的内存太小了,只给了512M 解决办 ...

  9. 085-PHP文件引用include(二)

    01.php <?php function foo() { global $color; include '02.php'; echo "A $color $fruit"; ...

  10. torch.cuda.FloatTensor

    Pytorch中的tensor又包括CPU上的数据类型和GPU上的数据类型,一般GPU上的Tensor是CPU上的Tensor加cuda()函数得到. 一般系统默认是torch.FloatTensor ...