先设置Mysql全局
疑问—-单片机矩阵键盘行列反转扫描法,单片机矩阵
学到矩阵键盘这一块对网上别人写的C代码有些疑问,希望有能看到的大牛帮助解答。
矩阵键盘和独立键盘原理图:
原理:对于图右侧的矩阵键盘,把P3口的低四位(P3.0 ~
P3.3)和高四位(P3.4 ~
P3.7)分别置1,只要有按键被按下,那么与之对应的P3口某一位将由高电平被拉低,两次分别测得了行值和列值即确定了哪一个按键被按下了。
欧洲杯竞猜平台 ,比如:先把低四位赋高电平即 P3 = 0000_1111 假如 S15 被按下了,那么
P3.2 就被拉成低电平即 P3 = 0000_1011 ,此时再把高四位赋高电平即 P3 =
1111_0000 ,那么 P3.5 就被拉成低电平即 P3 = 1101_0000
。最后,把两次测得的 P3 值相加 0000_1011 + 1101_0000 =
1101_1011(行列值为第三行第二列)
(1)网上最常见的写法:
1 P3 = 0x0f; //0000 1111
2 if ((P3 & 0x0f) != 0x0f) //按键检测
3 {
4 delay(3); //软件消抖
5 if ((P3 & 0x0f) != 0x0f) //按键检测
6 {
7 row_value = P3 & 0x0f; //扫描行值
8 P3 = row_value | 0xf0;
9 colume_value = P3 & 0xf0; //扫描列值
10 // while ((P3 & 0xf0) != 0xf0); //松手检测
11 return (row_value + colume_value);
12 }
13 }
(2):
P3 = 0x0f; //0000 1111
if ((P3 & 0x0f) != 0x0f) //按键检测
{
delay(3); //软件消抖
if ((P3 & 0x0f) != 0x0f) //按键检测
{
row_value = P3 & 0x0f; //扫描行值
P3 = 0xf0;
colume_value = P3 & 0xf0; //扫描列值
//while ((P3 & 0xf0) != 0xf0); //松手检测
return (row_value + colume_value);
}
}
(3):
P3 = 0x0f; //0000 1111
if ((P3 & 0x0f) != 0x0f) //按键检测
{
delay(3); //软件消抖
if ((P3 & 0x0f) != 0x0f) //按键检测
{
row_value = P3; //扫描行值
P3 = 0xf0;
colume_value = P3 ; //扫描列值
//while ((P3 & 0xf0) != 0xf0); //松手检测
return (row_value + colume_value);
}
}
(4)这个符合我所说的原理和例子:
P3 = 0x0f; //0000 1111
if (P3 != 0x0f) //按键检测
{
delay(3); //软件消抖
if (P3 != 0x0f) //按键检测
{
value = P3; //扫描行值
P3 = 0xf0;
value |= P3 ; //扫描列值
//while (P3 != 0xf0); //松手检测
return (value);
}
}
我已经用开发板实测了,上面这四个都对的。
我的疑问:我不明白为什么常见写法要写 &0x0f 、 &0xf0 或者
|0xf0
这样写有什么特别的作用没有?感觉写与不写原理上都对,那何必要写?(特别是写法
1 和写法 4 看起来差别蛮大的呀)
——————2017-06-04 22:05:02
如有错误还请指出,如有侵权还请告知,如需转载请注明出处!
本人博客:
学到矩阵键盘这一块对网上别人写的C代码有些疑问,希望有能看到的大牛帮助解答。…
1 cmd下输入:
2
3 mysql -uroot -p
4
5 root密码
6
7 use mysql;
8
9 update user set host = "%" where user = "root";
10
11 flush privileges;
12
13 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root' PASSWORD EXPIRE NEVER;
14
15 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
16
17 FLUSH PRIVILEGES;
P.S.1:第9行,网上很多方法是这样写的:GRANT
ALL ON *.* TO ‘root’@’%’;
,实测mysql8.0.12.0报错。
P.S.2:第13行,网上很多方法是这样写的:ALTER
USER ‘root’@’localhost’ IDENTIFIED BY ‘password’ PASSWORD EXPIRE NEVER;
,实测报错。
P.S.3:语句什么意思,自行百度。