ledBuff是缓冲区的起始位置,它的类档敬神型你可以从函数外面看到,因为它是一个全局变量。
&ledBuff是取ledBuff的地址,
(uint8 data*)&ledBuff是把取得的地址强制转换为uint8 data类型的指针。
((uint8 data*)&ledBuff+i是将这个指针位移,偏移量是i
*((uint8 data*)&ledBuff+i)最后加*号是将便宜后行亏的地稿液址中的值取出来,最终赋值给了P0.
这里P0是一个端口。
如果有电路图就好了...下面的程序是适合:
P0接的是数码管的a-g.高时字段亮
P1接的是三极管基极,低时选中显示位渗扰..
#include<reg51.h>
#define uchar unsigned char
uchar code CODE[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}//数字段码;变量名CODE
uchar code BIT_TAB[]={0xFE,0xFD,0xFB,0xF7}//数码管片选
uchar code DATA[]={1,2,3,4}/慧山/要前喊中显示的数字
uchar disp_temp//要显示的位变量
Display()
{
for(disp_temp=0disp_temp++)
{
P1=CODE[DATA[disp_temp]]//P1为段码扫描,
P0=BIT_TAB[disp_temp]//P0.0--P0.3为片选
if(disp_temp==3)
disp_temp=0
}
}
main()
{
Display()
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)