Arduino程序设计(四)按键消抖+按键计数
按键消抖+按键计数
- 前言
- 一、按键消抖
- 二、按键计数
- 1、示例代码
- 2、按键计数实验
- 参考资料
前言
- 本文主要介绍两种按键控制LED实验:
- 第一种是采用软件消抖的方法检测按键按下的效果;
- 第二种是根据按键按下次数,四个LED灯呈现不同的流水灯效果。
一、按键消抖
- 按键在按下时,由于机械和物理特定的原因,经常会产生一些开关变换,而这些变换会让程序误认为是短时间内进行了多次按键。
- 如何对输入信号进行消抖?也就是在一段短时间内进行两次检查来确保按键确实被按下。如果没有消抖的话,按下一次按键会产生很多不可预知的结果。
- 所以Arduino按键消抖是为了解决按键在物理接触瞬间可能产生多次触发的现象。
- 下面介绍两种常见的按键消抖方法:
- ① 使用外部电容(硬件消抖):通过在按键引脚和地之间并联一个适当大小的电容(例如:MCU复位电路采用0.1uF陶瓷电容),减少了按键连接和断开时产生的电压突变,同时也可以减少按键在短时间内多次触发的可能性。MCU复位电路如下图所示:
- ② 软件消抖:利用Arduino的延时函数或计时器来检测按键状态的变化,只有在按键状态保持一段时间后才认为按键有效。例如,当检测到按键按下时,可以设定一个延时时间,在延时时间内如果检测到按键保持按下状态,则认为按键有效。
按键消抖实验:
-
1、本实验采用Arduino UNO R3开发板及自主搭建电路的方式,实现预设功能。
-
2、按键消抖的电路图如下图所示:
-
3、功能实现:按下一个按键,控制LED灯亮50ms然后熄灭。
-
4、实验要求:采用延时消抖(方法1),编写按键扫描程序(方法2),计数器消抖(方法3)三种按键消抖方式实现功能。
代码实现(方法1):
//延时消抖,按键控制LED
//按下一个按键,控制LED灯亮50ms然后熄灭int buttonPin = 7;
int ledPin = 12;void setup() {pinMode(buttonPin, INPUT_PULLUP);pinMode(ledPin, OUTPUT);}
void loop() {if (digitalRead(buttonPin) == LOW){delay(10);if (digitalRead(buttonPin) == LOW){digitalWrite(ledPin, HIGH);delay(50);digitalWrite(ledPin, LOW);while (digitalRead(buttonPin) == LOW);}}
}
代码实现(方法2):
//编写按键扫描程序,实现按键消抖
//按下一个按键,控制LED灯亮50ms然后熄灭#define LED 12
#define KEY 7int KEY_NUM = 0; //按键键值存放变量,不等于1说明有按键按下void setup()
{pinMode(LED, OUTPUT); //定义LED为输出引脚pinMode(KEY, INPUT_PULLUP); //定义KEY为带上拉输入引脚
}void loop()
{ScanKey(); //按键扫描程序,当按键按下时候,该子程序会修改KEY_NUM的值if (KEY_NUM == 1) //是否按键按下{digitalWrite(LED, HIGH);delay(50);digitalWrite(LED, LOW);}
}void ScanKey() //按键扫描程序
{KEY_NUM = 0; //清空变量if (digitalRead(KEY) == LOW) //有按键按下{delay(10); //延时去抖动if (digitalRead(KEY) == LOW) //有按键按下{KEY_NUM = 1; //变量设置为1while (digitalRead(KEY) == LOW); //等待按键松手}}
}
代码实现(方法3):
//计数器消抖,按键控制LED
//按下一个按键,控制LED灯亮50ms然后熄灭const int buttonPin = 7; // 按键引脚
const int ledPin = 12; //LED引脚int buttonState = HIGH; // 按键状态
int lastButtonState = HIGH; // 上一次的按键状态
unsigned long lastDebounceTime = 0; // 上一次的触发时间
unsigned long debounceDelay = 10; // 消抖延时void setup() {pinMode(buttonPin, INPUT_PULLUP);pinMode(ledPin,OUTPUT);
}void loop() {int reading = digitalRead(buttonPin); // 读取按键引脚状态// 如果当前状态与上一次状态不同,更新上一次状态和触发时间if (reading != lastButtonState) {lastDebounceTime = millis();}// 如果经过了消抖延时,且当前状态与按键状态不同,更新按键状态if ((millis() - lastDebounceTime) > debounceDelay) {if (reading != buttonState) {buttonState = reading;// 按键按下时执行的操作if (buttonState == HIGH) {digitalWrite(ledPin, HIGH);delay(50);digitalWrite(ledPin, LOW);}}}lastButtonState = reading;
}
二、按键计数
1、示例代码
- 使用Arduino来实现按键计数。简单的示例代码如下:
//按键计数示例
const int buttonPin = 2; // 按钮连接到数字引脚2
int buttonState = 0; // 保存按钮状态
int count = 0; // 计数器void setup() {pinMode(buttonPin, INPUT); // 设置按钮引脚为输入模式Serial.begin(9600); // 打开串口通信
}void loop() {buttonState = digitalRead(buttonPin); // 读取按钮状态if (buttonState == HIGH) { // 如果按钮按下count++; // 计数器加1Serial.print("Button pressed. Count: ");Serial.println(count);delay(200); // 等待200毫秒,避免连续多次计数}
}
示例中,我们将一个按钮连接到Arduino的数字引脚2。循环中,我们读取按钮的状态,如果按钮被按下(高电平),计数器就会加1,并通过串口打印出计数器的值。为了避免按钮按下时的抖动,我们在每次计数后延迟200毫秒。
上传这个代码到Arduino板,然后打开串口监视器(波特率设置为9600),当你按下按钮时,你将看到计数器的值递增。
2、按键计数实验
-
(1)本实验采用Arduino UNO R3开发板及自主搭建电路的方式,实现预设功能。
-
(2)按键计数的电路图如下图所示:
-
(3)实现功能(基础):
-
① 第一次按下按键,LED1点亮;
-
② 第二次按下按键,LED1和LED2点亮;
-
③ 第三次按下按键,LED1~LED3点亮;
-
④ 第四次按下按键,LED1~LED4点亮;
-
⑤ 第五次按下按键,LED1~LED4熄灭;
-
⑥ 第六次按下按键,重复①现象;
-
⑦ 第七次按下按键,重复②现象……,以此类推。
代码实现:
//编写按键扫描程序,实现按键计数
/*实验现象:
① 第一次按下按键,LED1点亮;
② 第二次按下按键,LED1和LED2点亮;
③ 第三次按下按键,LED1~LED3点亮;
④ 第四次按下按键,LED1~LED4点亮;
⑤ 第五次按下按键,LED1~LED4熄灭;
⑥ 第六次按下按键,重复①现象;
⑦ 第七次按下按键,重复②现象……,以此类推。
*/const int KEY = 7; //按键引脚
const int LED1 = 9; //LED1引脚
const int LED2 = 10; //LED2引脚
const int LED3 = 11; //LED3引脚
const int LED4 = 12; //LED4引脚int KEY_count = 0; //按键计数void setup()
{pinMode(KEY, INPUT_PULLUP); //定义KEY为带上拉输入引脚pinMode(LED1, OUTPUT); //定义LED1为输出引脚pinMode(LED2, OUTPUT); //定义LED2为输出引脚pinMode(LED3, OUTPUT); //定义LED3为输出引脚pinMode(LED4, OUTPUT); //定义LED4为输出引脚
}void loop()
{ScanKey(); //按键扫描程序,当按键按下时候,该子程序会修改KEY_count的值switch (KEY_count) {case 0:{digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);}break;case 1:{digitalWrite(LED1, HIGH);}break;case 2:{digitalWrite(LED1, HIGH);digitalWrite(LED2, HIGH);}break;case 3:{digitalWrite(LED1, HIGH);digitalWrite(LED2, HIGH);digitalWrite(LED3, HIGH);}break;case 4:{digitalWrite(LED1, HIGH);digitalWrite(LED2, HIGH);digitalWrite(LED3, HIGH);digitalWrite(LED4, HIGH);}break;default:{KEY_count = 0;}}
}void ScanKey() //按键扫描程序
{if (digitalRead(KEY) == LOW) //有按键按下{delay(10); //延时去抖动if (digitalRead(KEY) == LOW) //有按键按下{KEY_count++; //按键计数while (digitalRead(KEY) == LOW); //等待按键松手}}
}
- (4)实现功能(进阶):
- ① 第一次按下按键,LED1和LED3亮500ms后熄灭,间隔150ms后,LED2和LED4亮150ms后熄灭,间隔150ms后,LED1和LED3亮150ms后熄灭……,重复操作。
- ② 第二次按下按键,LED1~LED4从左往右依次点亮,等LED4熄灭后,再从左往右依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。
- ③ 第三次按下按键,LED1~LED4从右往左依次点亮,等LED1熄灭后,再从右往左依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。
- ④ 第四次按下按键,LED1~LED4从左往右依次点亮,再从右往左依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。
- ⑤ 第五次按下按键,LED1~LED4熄灭。
- ⑥ 第六次按下按键,重复①现象
- ⑦ 第七次按下按键,重复②现象……,以此类推。
代码实现:
//编写按键扫描程序,实现按键计数
//注意:按下按键后,即下一次按下按键前,时间间隔>10s
/*实验现象:① 第一次按下按键,LED1和LED3亮150ms后熄灭,间隔150ms后,LED2和LED4亮150ms后熄灭,间隔150ms后,LED1和LED3亮150ms后熄灭……,重复操作。② 第二次按下按键,LED1~LED4从左往右依次点亮,等LED4熄灭后,再从左往右依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。③ 第三次按下按键,LED1~LED4从右往左依次点亮,等LED1熄灭后,再从右往左依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。④ 第四次按下按键,LED1~LED4从左往右依次点亮,再从右往左依次点亮,重复操作,相邻两个LED灯亮灭的时间间隔为50ms。⑤ 第五次按下按键,LED1~LED4熄灭。⑥ 第六次按下按键,重复①现象⑦ 第七次按下按键,重复②现象……,以此类推。
*/const int KEY = 7; //按键引脚
const int LED1 = 9; //LED1引脚
const int LED2 = 10; //LED2引脚
const int LED3 = 11; //LED3引脚
const int LED4 = 12; //LED4引脚int KEY_count = 0; //按键计数void setup()
{pinMode(KEY, INPUT_PULLUP); //定义KEY为带上拉输入引脚pinMode(LED1, OUTPUT); //定义LED1为输出引脚pinMode(LED2, OUTPUT); //定义LED2为输出引脚pinMode(LED3, OUTPUT); //定义LED3为输出引脚pinMode(LED4, OUTPUT); //定义LED4为输出引脚
}void loop()
{ScanKey(); //按键扫描程序,当按键按下时候,该子程序会修改KEY_count的值switch (KEY_count) {case 0:{digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);}break;case 1:{//第一次按下按键digitalWrite(LED1, HIGH);digitalWrite(LED2, LOW);digitalWrite(LED3, HIGH);digitalWrite(LED4, LOW);delay(150);digitalWrite(LED1, !digitalRead(LED1));digitalWrite(LED2, !digitalRead(LED2));digitalWrite(LED3, !digitalRead(LED3));digitalWrite(LED4, !digitalRead(LED4));delay(150);}break;case 2:{//刷新LED1~LED4状态digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);//第二次按下按键digitalWrite(LED1, HIGH);delay(50);digitalWrite(LED1, !digitalRead(LED1));digitalWrite(LED2, HIGH);delay(50);digitalWrite(LED2, !digitalRead(LED2));digitalWrite(LED3, HIGH);delay(50);digitalWrite(LED3, !digitalRead(LED3));digitalWrite(LED4, HIGH);delay(50);digitalWrite(LED4, !digitalRead(LED4));delay(50);}break;case 3:{//刷新LED1~LED4状态digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);//第三次按下按键digitalWrite(LED4, HIGH);delay(50);digitalWrite(LED4, !digitalRead(LED4));digitalWrite(LED3, HIGH);delay(50);digitalWrite(LED3, !digitalRead(LED3));digitalWrite(LED2, HIGH);delay(50);digitalWrite(LED2, !digitalRead(LED2));digitalWrite(LED1, HIGH);delay(50);digitalWrite(LED1, !digitalRead(LED1));delay(50);}break;case 4:{//刷新LED1~LED4状态digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);//第四次按下按键digitalWrite(LED1, HIGH);delay(50);digitalWrite(LED1, !digitalRead(LED1));digitalWrite(LED2, HIGH);delay(50);digitalWrite(LED2, !digitalRead(LED2));digitalWrite(LED3, HIGH);delay(50);digitalWrite(LED3, !digitalRead(LED3));digitalWrite(LED4, HIGH);delay(50);digitalWrite(LED4, !digitalRead(LED4));delay(50);digitalWrite(LED4, HIGH);delay(50);digitalWrite(LED4, !digitalRead(LED4));digitalWrite(LED3, HIGH);delay(50);digitalWrite(LED3, !digitalRead(LED3));digitalWrite(LED2, HIGH);delay(50);digitalWrite(LED2, !digitalRead(LED2));digitalWrite(LED1, HIGH);delay(50);digitalWrite(LED1, !digitalRead(LED1));delay(50);}break;default:{digitalWrite(LED1, LOW);digitalWrite(LED2, LOW);digitalWrite(LED3, LOW);digitalWrite(LED4, LOW);KEY_count = 0;}}
}void ScanKey() //按键扫描程序
{if (digitalRead(KEY) == LOW) //有按键按下{delay(10); //延时去抖动if (digitalRead(KEY) == LOW) //有按键按下{KEY_count++; //按键计数while (digitalRead(KEY) == LOW); //等待按键松手}}
}
注意:按下按键后,即下一次按下按键前,时间间隔>10s。
参考资料
参考资料1: 【Arduino官方教程】数字处理示例(三):按键防抖
参考资料2: 【Arduino官方教程】数字处理示例(五):按键状态变化检测
相关文章:
Arduino程序设计(四)按键消抖+按键计数
按键消抖按键计数 前言一、按键消抖二、按键计数1、示例代码2、按键计数实验 参考资料 前言 本文主要介绍两种按键控制LED实验:第一种是采用软件消抖的方法检测按键按下的效果;第二种是根据按键按下次数,四个LED灯呈现不同的流水灯效果。 一…...
Module not found: Error: Can‘t resolve ‘vue-pdf‘ in ‘xxx‘
使用命令npm run serve时vue项目报错: Module not found: Error: Cant resolve vue-pdf in xxx 解决方案: 运行命令: npm install vue-pdf --save --legacy-peer-deps 即可解决。 再次顺利执行npm run serve...
ELK之LogStash介绍及安装配置
一、logstash简介 集中、转换和存储数据 Logstash 是免费且开放的服务器端数据处理管道,能够从多个来源采集数据,转换数据,然后将数据发送到您最喜欢的“存储库”中。 Logstash 能够动态地采集、转换和传输数据,不受格式或复杂度的…...
docker学习(1)
1、容器与虚拟机的对比: 虚拟机(virtual machine)就是带环境安装的一种解决方案。 它可以在一种操作系统里面运行另一种操作系统,比如在Windows10系统里面运行Linux系统CentOS7。 应用程序对此毫无感知,因为虚拟机看…...
UE5 Niagara基础知识讲解
文章目录 前言官方文档发射器生成(Emitter Spawn)发射器更新(Emitter Update)Spawn Rate(生成速率)粒子生成(Particle Spawn)Initialize Particle(初始化粒子)粒子生命周期粒子颜色粒子大小Shape Location(形状位置)形状位置Add Velocity(添加速度)粒子速度Curl …...
缓存穿透、缓存击穿和缓存雪崩
👏作者简介:大家好,我是爱发博客的嗯哼,爱好Java的小菜鸟 🔥如果感觉博主的文章还不错的话,请👍三连支持👍一下博主哦 📝社区论坛:希望大家能加入社区共同进步…...
自动化编排工具Terraform介绍(一)
Terraform是什么?: Terraform 是 HashiCorp 公司旗下的 Provision Infrastructure 产品, 是 AWS APN Technology Partner 与 AWS DevOps Competency Partner。Terraform 是一个 IT 基础架构自动化编排工具,它的口号是“Write, Plan, and Create …...
zhm_real/MotionPlanning运动规划库中A*算法源码详细解读
本文主要对zhm_real/MotionPlanning运动规划库中A*算法源码进行详细解读,即对astar.py文件中的内容进行详细的解读,另外本文是 Hybrid A * 算法源码解读的前置文章,为后续解读Hybrid A * 算法源码做铺垫。 astar.py文件中的源码如下ÿ…...
SpringMVC中Controller层获取前端请求参数的几种方式
SpringMVC中Controller层获取前端请求参数的几种方式 1、SpringMVC自动绑定2、使用RequestParam 注解进行接收3、RequestBody注解(1) 使用实体来接收JSON(2)使用 Map 集合接收JSON(3) 使用 List集合接收JSO…...
记Flask-Migrate迁移数据库失败的两个Bug——详解循环导入问题
文章目录 Flask-Migrate迁移数据库失败的两个Bug1、找不到数据库:Unknown database ***2、迁移后没有效果:No changes in schema detected. Flask-Migrate迁移数据库失败的两个Bug 1、找不到数据库:Unknown database ‘***’ 若还没有创建数…...
在线求助。。npm i 报错,连公司内部网,无法连外网
各位前端朋友 ,有没有遇到我这种npm i 报错的问题。 公司内网,无法连外网,使用公司内部的Nexus镜像源 我在公司内网执行npm i 报错,报network连接失败。 我都已经在npm设置了内部镜像源,它为啥还要去外网下载呢。而…...
TCP/UDP/IP协议简介
IP协议简介 特指为实现一个相互连接的网络系统上从源地址到目的地址传输数据包(互联网数据包) 所提供必要功能的协议 特点: 不可靠:不能保证IP数据包能够成功的到达它的目的地只能提供尽力而为的传输服务。 无连接:IP并不维护任何关于后续数…...
写点感想3:关于本人近期的说明与一点感受
按照我今年以来7月之前的更新频率,我已经好久没有更新博文了(或者说静下来写点东西)。 我其实有规划蛮多的有意思的且想要去研究下的topic,最近好久没能更新主要的原因包括: 开启了我职业生涯的第二份工作:在某研究院工作2年零3…...
opencv-全景图像拼接
运行环境 python3.6 opencv 3.4.1.15 stitcher.py import numpy as np import cv2class Stitcher:#拼接函数def stitch(self, images, ratio0.75, reprojThresh4.0,showMatchesFalse):#获取输入图片(imageB, imageA) images#检测A、B图片的SIFT关键特征点,并计算…...
如何将下载的安装包导入PyCharm
1. 下载安装包 这里以pyke为例。下载好之后解压缩,然后放入/Lib/site-packages/pyke-1.1.1 2. 打开PyCharm的终端进行安装 python setup.py install 3. 安装好之后导入即可使用 import pyke...
【redis问题】Caused by: io.netty.channel
遇到的问题: 在使用 RedisTemplate 连接 Redis 进行操作的时候,发生了如下报错: 测试代码为: 配置文件: 问题根源: redis没有添加端口映射解决方案: 删除原来的redis容器,添加新…...
Elasticsearch 处理地理信息
1、GeoHash GeoHash是一种地理坐标编码系统,可以将地理位置按照一定的规则转换为字符串,以方便对地理位置信息建立空间索引。首先要明确的是,GeoHash代表的不是一个点而是一个区域。GeoHash具有两个显著的特点:一是通过改变 G…...
ARM开发,stm32mp157a-A7核IIC实验(采集温湿度传感器值)
1.实验目标:采集温湿度传感器值; 2.分析框图(模拟IIC控制器); 3.代码; ---iic.h封装时序协议头文件--- #ifndef __IIC_H__ #define __IIC_H__ #include "stm32mp1xx_gpio.h" #include "st…...
021-从零搭建微服务-短信服务(一)
写在最前 如果这个项目让你有所收获,记得 Star 关注哦,这对我是非常不错的鼓励与支持。 源码地址(后端):https://gitee.com/csps/mingyue 源码地址(前端):https://gitee.com/csps…...
基于jenkins自动化部署PHP环境
实验环境 操作系统 IP地址 主机名 角色 CentOS7.5 192.168.147.141 git git服务器 CentOS7.5 192.168.147.142 Jenkins git客户端 jenkins服务器 CentOS7.5 192.168.147.143 web web服务器 具体环境配置见上一篇! 准备git仓库 [rootgit ~]# su -…...
数据库表结构导出为word、html、markdown【转载,已解决,已验证,开源】
注:本文为gitcode代码验证,转载gitcode gitcode:https://gitcode.net/mirrors/pingfangushi/screw?utm_sourcecsdn_github_accelerator 整理数据库文档:https://mp.weixin.qq.com/s/Bo_U5_cl82hfQ6GmRs2vtA <!--数据库文档核…...
【计算机视觉|生成对抗】用于高保真自然图像合成的大规模GAN训练用于高保真自然图像合成的大规模GAN训练(BigGAN)
本系列博文为深度学习/计算机视觉论文笔记,转载请注明出处 标题:Large Scale GAN Training for High Fidelity Natural Image Synthesis 链接:[1809.11096] Large Scale GAN Training for High Fidelity Natural Image Synthesis (arxiv.org…...
三维重建_体素重建_空间雕刻法/体素着色法
目录 1. 三角化和体素重建的区别 2. 空间雕刻法 空间雕刻法的一致性定义 空间雕刻法具体实现 基于八叉树的空间雕刻法具体实现编辑 空间雕刻法效果展示 3. 体素着色法 体素着色法的缺点:不唯一性编辑 体素着色法不唯一性解决措施编辑 体素着色发实验环境与…...
4-redis哨兵搭建安装
1.先决条件 1.1.OS基础配置 CentOS为了能够正常安装redis,需要对CentOS进行常规的一些基础配置,主要有:关闭防火墙与selinux,设置主机名,配置虚拟机IP地址使其能够与外网ping通,配置IP地址与主机名映射,配置yum源。具体配置参见: Linux常规基础配置_小黑要上天的博客…...
架构评估-架构师之路(十二)
软件系统质量属性 软件系统质量熟悉分为 开发期质量属性 和 运行期质量属性。 质量属性 性能:指 系统的响应能力,如 响应时间,吞吐率。 设计策略:优先级队列、增加计算资源、减少计算开销、引入并发机制、采用资源调度。 可靠…...
手写模拟SpringBoot核心流程(二):实现Tomcat和Jetty的切换
实现Tomcat和Jetty的切换 前言 上一篇文章我们聊到,SpringBoot中内置了web服务器,包括Tomcat、Jetty,并且实现了SpringBoot启动Tomcat的流程。 那么SpringBoot怎样自动切换成Jetty服务器呢? 接下来我们继续学习如何实现Tomcat…...
Python土力学与基础工程计算.PDF-土的三项组成
5.3 Python求解 Python 求解代码如下: 1. # 定义已知参数 2. G_s 2.7 # 比重 3. w 0.2 # 含水量 4. e 0.6 # 孔隙比 5. gamma_w 9.81 # 水的重度 6. 7. # 根据公式计算饱和度 8. S_r G_s * w / e 9. print("饱和度为", S_r) 10. 11.…...
危化安全生产信息化平台在煤化领域的应用
一、背景介绍 煤化工行业是一个集煤炭、石油、化工等多种产业于一体的综合性行业,其特点是工艺流程复杂、设备繁多、安全隐患大。近年来,随着煤化工行业的快速发展,安全生产问题日益凸显。为了有效提高危化安全生产水平,某煤化工…...
Linux(CentOS)运维脚本工具集合
使用说明 备份指定目录 # 备份指定目录文件到指定目录,备份文件名称为:备份目录最后一层目录"_"日期.tar.gz # 第一个参数:backdir 第二参数:备份文件保存目录 第三个参数:备份目录/文件 sh script.sh backdir /root/…...
如何制作产品网站模板下载地址/免费广告投放网站
2019独角兽企业重金招聘Python工程师标准>>> 事实证明,跟遗留代码打交道未必需要花费数天时间去研究晦涩难懂的注释。要想找到并修复漏洞,开发者可采用简单的测试工具来对问题抽丝剥茧。 跟遗留代码打交道会是比较困难的,尤其是如…...
那些网站做调查能赚钱/东莞谷歌推广
9.4版本添加uuid-ossp很简单,只需要添加扩展包内容即可 CREATE EXTENSION "uuid-ossp"; 具体路径是在:/usr/pgsql-9.4/share/extension/uuid-ossp--1.0.sql 刚开始采用以前的方法手动创建,直接提示直接使用create extension即…...
工艺品网站域名/百度收录提交入口网址是什么
现象:长时间不关机,息屏后无法唤醒。电源指示灯亮,但是是黑屏 拔电重开,还是黑屏,显示器提示进入节电模。 首先怀疑是内存条松了,或者接触不良,本人机器这边解决步骤如下。 1,拔插…...
佛山企业网站制作公司/武汉seo服务外包
窝里个去,不使用sudo吧rvm requirements执行不成功。加上sudo吧rvm requirements调用的brew install又不行。好吧,就按上面说的将brew转换到root模式。 1 2 3 4 5 6 ls -al /usr/local/bin/brew -rwxr-xr-x 1 twer admin 703 Mar 14 2013 /usr/local/b…...
夺目视频制作网站/做营销型网站的公司
.text_overflow{width:6.5rem;white-space:nowrap;text-overflow:ellipsis;-o-text-overflow:ellipsis;overflow:hidden; }...
宁波网络营销推广外包公司/长沙靠谱关键词优化公司电话
看到标题,可能有的同学会说不是可以敲代码得到相应的可视化图形的吗?为什么还要用Tableau这种专业的数据分析软件呢?那么我觉得得先认识一下什么是Tableau?在开始学习之前,我想先做一个思维导图来说明学习Tableau的顺序…...