Arduino 串口的一些高级用法
来源:
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中的程序。
|
void setup() {
|
|
|
Serial.begin(9600);
|
|
|
while (!Serial) {;}
|
|
|
}
|
|
|
void loop() {
|
|
|
}
|
3.read和peek输入方式的差异 串口接收到的数据都会暂时存放在接收缓冲区中,使用read()与peek()都是从接收缓冲区中读取数据。不同的是,使用read()读取数据后,会将该数据从接收缓冲区移除;而使用peek()读取时,不会移除接收缓冲区中的数据。 你可以使用以下程序,观察其运行结果:
|
char col;
|
|
|
void setup() {
|
|
|
Serial.begin(9600);
|
|
|
}
|
|
|
void loop() {
|
|
|
while(Serial.available()>0){
|
|
|
col=Serial.read();
|
|
|
Serial.print("Read: ");
|
|
|
Serial.println(col);
|
|
|
delay(1000);
|
|
|
}
|
|
|
}
|
|
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型数据。
|
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 串口的一些高级用法的更多相关文章
- Arduino串口的一些高级用法
1.配置串口通信数据位.校验位.停止位通常我们使用Serial.begin(speed)来完成串口的初始化,这种方式,只能配置串口的波特率.而使用Serial.begin(speed, config) ...
- Arduino - 串口操作函数与示例代码大全
来源:https://blog.csdn.net/iracer/article/details/50334041 Arduino - 串口操作函数与示例代码大全 本文总结了Arduino常用串口操作函 ...
- Visual Studio 宏的高级用法
因为自 Visual Studio 2012 开始,微软已经取消了对宏的支持,所以本篇文章所述内容只适用于 Visual Studio 2010 或更早期版本的 VS. 在上一篇中,我已经介绍了如何编 ...
- SolrNet高级用法(分页、Facet查询、任意分组)
前言 如果你在系统中用到了Solr的话,那么肯定会碰到从Solr中反推数据的需求,基于数据库数据生产索引后,那么Solr索引的数据相对准确,在电商需求中经常会碰到菜单.导航分类(比如电脑.PC的话会有 ...
- sqlalchemy(二)高级用法
sqlalchemy(二)高级用法 本文将介绍sqlalchemy的高级用法. 外键以及relationship 首先创建数据库,在这里一个user对应多个address,因此需要在address上增 ...
- Solr学习总结(六)SolrNet的高级用法(复杂查询,分页,高亮,Facet查询)
上一篇,讲到了SolrNet的基本用法及CURD,这个算是SolrNet 的入门知识介绍吧,昨天写完之后,有朋友评论说,这些感觉都被写烂了.没错,这些基本的用法,在网上百度,资料肯定一大堆,有一些写的 ...
- 再谈Newtonsoft.Json高级用法
上一篇Newtonsoft.Json高级用法发布以后收到挺多回复的,本篇将分享几点挺有用的知识点和最近项目中用到的一个新点进行说明,做为对上篇文章的补充. 阅读目录 动态改变属性序列化名称 枚举值序列 ...
- Jquery remove 高级用法
Jquery remove 高级用法 html 代码 <div class="file-image">abc1111</div><div class= ...
- Newtonsoft.Json高级用法(转)
手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...
随机推荐
- 为什么ping不通google.com
前言 为什么在ping不通Google的时候,我们却可以web直接访问Google (已开启SSR 翻 墙) SSR访问Google 因为GFW的限制导致国内无法直接访问谷歌,那么SSR为什么能绕过限 ...
- SpringMVC-08-SpringMVC层编写
SpringMVC层编写 web.xml DispatcherServlet <!--DispatcherServlet--> <servlet> <servlet-na ...
- [深入理解JVM虚拟机]第2章-Java内存区域与内存溢出异常
2.0引-Java内存区域中,栈内存和堆内存分别装什么,为什么? 栈:解决程序的运行问题,即程序如何执行,或者说如何处理数据. 堆:解决的是数据存储的问题,即数据怎么放,放在哪儿. 参考链接https ...
- in多值优化
〇.问题 今天ocp群里有人问 SELECT * FROM table WHERE id IN(11,2,3,44,...) 在in里面有大量数据4000+,有什么 好的处理方式吗? 我的优化方案的总 ...
- 《方法总结》C路的方法发现
C语言方法荟萃 定义一个最大值和最小值:#define max(x,y) ( x>y?x:y ) #define min(x,y) ( x<y?x:y ) &&: 说得 ...
- DASH流媒体MPD中的segmentTemplate
SegmentTemplate利用MPD中的属性代入公式计算可以得到相关通配符的数值,来提供给客户端进行相关地址解析.相较于segmentList,使用 SegmentTemplate 的方式,能够很 ...
- Docker实战(4):Docker错误记一笔
创建容器的时候报错WARNING: IPv4 forwarding is disabled. Networking will not work. 解决办法: vim /usr/lib/sysctl.d ...
- k8s重要概念及部署k8s集群(一)
k8s介绍 Kubernetes(k8s)是Google开源的容器集群管理系统(谷歌内部:Borg).在Docker技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功 ...
- php处理的图片无法进CDN缓存
今天发现线上有个问题,线上一个图片域名,在前端已经加了CDN缓存,不落缓存,则用PHP动态实现图片缩放,但经PHP处理过的图片输出后,每次都要从后端读取,后端服务器压力瞬间增加,经分析,PHP中没有作 ...
- Group Convolution组卷积
思路按照常规卷积到组卷积来. 常规卷积: 如果输入feature map尺寸为C∗H∗W C*H*WC∗H∗W,卷积核有N NN个,输出feature map与卷积核的数量相同也是N NN,每个卷积核 ...
