从单片机基础到程序框架(全集 2019pdf版).pdf - 第146页

二进制:100 100011010 0 第 4 个数 十进制:85 十六进制:5 5 二进制:101 0101 第 5 个数 十进制:84 十六进制:5 4 二进制:101 0100 第 6 个数 十进制:2 十六进制:2 二进制:10 第 7 个数 十进制:4 十六进制:4 二进制:100 分析: 通过实验结 果,发现在单 片机上的计算 结果和 我们的分析是 一致的。 【34.7 如何在单片机上练习本章节 C 语言程序?】 直接复制前…

100%1 / 836
c=H; //c 的低 8 位被 H 覆盖,也就是此时 c 的低 8 位得到了 H 的各位值。
c=c<<8; //及时 c 的低 8 位移动到高 8 位,同时 c 原来的低 8 位被填入 0
c=c+L; //此时 c 再加 L,c 的低 8 位就 L 的值。此时 c 得到了 H L 合并而来的值。
//左移的应用之二:聚焦在某个变量的某个位。
d=d|(1<<0); //对第 0 位置 1。
e=e&(~(1<<0)); //对第 0 位清零。
//左移简写。
f<<=1; //就相当于 f=f<<1;
g<<=2; //就相当于 g=g<<2;
View(a); //把第 1 个数 a 发送到电脑端的串口助手软件上观察。
View(b); //把第 2 个数 b 发送到电脑端的串口助手软件上观察。
View(c); //把第 3 个数 c 发送到电脑端的串口助手软件上观察。
View(d); //把第 4 个数 d 发送到电脑端的串口助手软件上观察。
View(e); //把第 5 个数 e 发送到电脑端的串口助手软件上观察。
View(f); //把第 6 个数 f 发送到电脑端的串口助手软件上观察。
View(g); //把第 7 个数 g 发送到电脑端的串口助手软件上观察。
while(1)
{
}
}
/*---C 语言学习区域的结束。-----------------------------------------------*/
在电脑串口助手软件上观察到的程序执行现象如下:
开始...
1 个数
十进制:10
十六进制:A
二进制:1010
2 个数
十进制:20
十六进制:14
二进制:10100
3 个数
十进制:4660
十六进制:1234
二进制:1001000110100
4 个数
十进制:85
十六进制:55
二进制:1010101
5 个数
十进制:84
十六进制:54
二进制:1010100
6 个数
十进制:2
十六进制:2
二进制:10
7 个数
十进制:4
十六进制:4
二进制:100
分析:
通过实验结果,发现在单片机上的计算结果和我们的分析是一致的。
【34.7 如何在单片机上练习本章节 C 语言程序?】
直接复制前面章节中第十一节的模板程序,练习代码时只需要更改C 语言学习区域”代码就可以了,
其它部分的代码不要动。编译后,把程序下载进带串口 51 习板,通过电脑端的串口助手软件就可以观
察到不同的变量数值,详细方法请看第十一节内容。
第三十五节:移位运算的右移。
【35.1 “右移”运算。
“右移”运算也是以位为单位进行运算的。位是指二进制中的某一位,位只能是 0 或者 1。欲理解某个
“右移”运算的内部规律,必先把该数展开成二进制的格式,然后才好分析。“右移”运算的符号“>>”
它的通用格式如下:
“保存变量”=“被移数”>>n;
运算规律是“被移数”先被复制一份放到某个隐蔽的临时变(也称作寄存器然后对此临时变量展
开成二进制的格式,左边是高位右边是低位,此二进制格式的临时变量被整体由左往右移动了 n 原来
左边由于数据位移动而新空出的高 n 位数据被直接填 0,而右边由于数据位移动而导致低 n 位数据被直接
覆盖,最后再把移位运算的结果存入“保存变量”。多问一句,这行代码执行完毕后,“保存变量”和“被移
数”到底哪个变量发生了变化,哪个变量维持不变?大家记住,只有赋值语句“=”左边的“保存变量”发
生数值变化,而右边的“被移数”没有发生变化,因为“被移数”被操作的不是它自己本身而是它的复制
品替身(某个隐蔽的临时变量,也称寄存器)
上述通用格式中的 n 代表被一次右移的位数,可以取 0,当 n 等于 0 的时候,代表右移 0 位,其实就是
数值维持原来的样子没有发生变化。
现在举一个完整的例子来分析“>>”右移运算的规律。有两个 unsigned char 类型的变量 a b,它们
的数值都是十进制的 5,求 a=a>>1 b=b>>2 的结果分别是多少?分析步骤如下:
第一步:先把 a b 变量原来的数值以二进制的格式展开。十进制转二进制的方法请参考前面第 14,15,
16 节的内容。
a 变量是十进 5,它的二进制格式是: 00000101。
b 变量是十进 5,它的二进制格式是: 00000101。
第二步:将 a 右移 1 ,将 b 右移 2
(1)a=a>>1,就是将 a 右移 1 位。
a 右移前是 -> 00000101
a 右移 1 位后是 -> 00000010
结果分析:把二进制的 00000010 转换成十六进制是0x02。转换成十进制是 2。所以 a 初始值是 5,
右移 1 位后的结果 2。
(2)b=b>>2,就是将 b 右移 2 位。
b 右移前是 -> 00000101
b 右移 2 位后是 -> 00000001
结果分析:把二进制的 00000001 转换成十六进制是0x01。转换成十进制是 1。所以 b 初始值是 5,
右移 2 位后的结果 1。
【35.2 “右移”与除法的关系。
左移一位相当于乘以 2,而右移跟左移恰恰相反,右移一位相当于除以 2,注意,这里的除法是整除
不带小数点的。比如上面例子,5 右移 1 位就变成了 2相当于 5 整除 2 2)5 右移 2 位就变成了 1(相
当于 5 整除 2 再整 2 等于 1)这个现象背后的规律是:在右移运算中,每右移 1 位就相当于整除 2,右移
2 位相当于整除 2 再整 2,右移 3 位相当于整除 2 整除 2 再整除 2......以此类推这个规律反过来从除