C51中“bit”是如何使用的?

一下程序为74HC595串行移入一个字节后输出寄存器。请问一下“bit”是如何实现从高位到低位分别移入的?“bit”怎么用?#include<regx52.h>sbits... 一下程序为74HC595串行移入一个字节后输出寄存器。请问一下“bit”是如何实现从高位到低位分别移入的?“bit”怎么用?
#include <regx52.h>
sbit sclk=P2^0;
sbit sda=P2^1;
sbit slck=P2^2;
int tab[10]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
void delay()
{
int i,j;
for(i=0;i<255;i++)
for(j=0;j<80;j++);
}
void bit_dat(bit i)
{ sclk=0;
sda=i;
sclk=1;
}
void dat(char i)
{
slck=0;
bit_dat((bit)(tab[i]&0x80));
bit_dat((bit)(tab[i]&0x40));
bit_dat((bit)(tab[i]&0x20));
bit_dat((bit)(tab[i]&0x10));
bit_dat((bit)(tab[i]&0x08));
bit_dat((bit)(tab[i]&0x04));
bit_dat((bit)(tab[i]&0x02));
bit_dat((bit)(tab[i]&0x01));
slck=1;
}
main()
{ int i;
while(1)
{
for(i=0;i<10;i++)
{dat(i);
delay();
}
i=0;
}
}
展开
 我来答
阿__四
推荐于2018-03-14
知道答主
回答量:1
采纳率:0%
帮助的人:0
展开全部
比如i=0时,tab[i]的值为0x3f,那么这句bit_dat((bit)(tab[i]&0x80));的作用是:

第一步:tab[i]与0x80作位与,即0x3f与0x80作位与(与0x40相位与就是取了第6位),这样的效果是取得了0x3f的最高位(第7位),其它位全部被屏蔽为0

第二步:作int向bit强制转换,向bit转换有一个规则,只要待转换前变量是非零,转换后的bit类型变量即为1,否则为0,这里,0x3f&0x80的结果为0,也就是((bit)(tab[i]&0x80))的结果为0

第三步:调用bit_dat函数,向外设写入这一位。

后面的(bit_dat((bit)(tab[i]&0x40))句子就是取次高位,后面的依此类推,就可以从高位取到低位了。

参考资料:

imkarayi9d4f
推荐于2016-04-21 · TA获得超过1552个赞
知道小有建树答主
回答量:1164
采纳率:85%
帮助的人:602万
展开全部
bit 是定义一个位变量。
例如:
void main(void)
{
bit bIsBit ;
bIsBit=1;
if( bIsBit == 1 )
{
;//如果位变量=1时。
}
else
{
;//如果位变量=0时。
}
while( bIsBit==0 )
{
;//如果位变量=0时,死循环。
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式