int i = (0xf000 & t) >> 12;
时间: 2024-04-26 17:22:03 浏览: 16
这行代码首先对变量t的值进行了按位与运算,0xf000是一个十六进制的数,它的二进制表示为1111 0000 0000 0000,所以这个操作保留了t的高4位,将低12位全部清零。然后,使用右移操作符>>将结果向右移动12位,相当于将高4位移到低4位,得到的结果i即为t的高4位的值,其值范围为0~15。
相关问题
#include<reg52.h> #define uchar unsigned char ; #define uint unsigned int ; Ledcode[6][8]={ {0x01,0xEF,0xEF,0xEF,0x01,0xFF,0xFF,0xFF},//H {0x83,0x7D,0x75,0x7B,0x85,0xFF,0xFF,0xFF},//Q {0x03,0xFD,0xFD,0xFD,0x03,0xFF,0xFF,0xFF},//U {0xEF,0xEF,0x01,0xEF,0xEF,0xFF,0xFF,0xFF},//+ {0x01,0xF7,0x0F,0xF7,0x01,0xFF,0xFF,0xFF},//W {0xFB,0xFD,0x7D,0x03,0x7F,0xFF,0xFF,0xFF}};//J void delayms(int n) { int i; int j; for(i=0;i<n;i++) for(j=0;j<110;j++); } void main() { int i=0; int j=0; int flag=0; int t=25; int time=0; while(1) { P0=0XFF; P1=0X00; delayms(1000); for(j=0;j<8;j++) { time=100; for(time=100;time>0;time--) { for(i=0;i<8;i++) { P0=(0X80>>i); P1 = Ledcode[j][i]; delayms(2); P0=0X00; P1=0XFF; } } } while(1) { for(i=0;i<8;i++) { if(flag==1) { for(t=25;t>0;t--) { for(j=0;j<8;j++) { P0=(0X80>>j);//ÓÒÒÆjλ P1=Ledcode[i][j]; delayms(25-t); P0=0X00; P1=0XFF; delayms(t); } } flag=0; delayms(1000); } else if(flag==0) { for(t=0;t<25;t++) { for(j=0;j<8;j++) { P0=(0X80>>j);//ÓÒÒÆjλ P1=Ledcode[i][j]; delayms(25-t); P0=0X00; P1=0XFF; delayms(t); } } flag=1; delayms(1000); } } if(i==8) { i=0; P0=0X00; P1=0XFF; break; } } } }优化一下这段代码
这段代码可以进行如下优化:
1. 在循环中使用常量的地方可以使用宏定义,例如将 `delayms(1000)` 定义为 `DELAY_1000MS`。
2. 在延时函数中可以使用定时器来进行延时,提高精度。
3. 将循环中的常量赋值移到循环外部,减少每次循环的赋值操作。
4. 在循环中使用位运算来代替移位操作,提高效率。
优化后的代码如下所示:
```
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
#define DELAY_1000MS 1000
uchar Ledcode[6][8] = {
{0x01, 0xEF, 0xEF, 0xEF, 0x01, 0xFF, 0xFF, 0xFF}, //H
{0x83, 0x7D, 0x75, 0x7B, 0x85, 0xFF, 0xFF, 0xFF}, //Q
{0x03, 0xFD, 0xFD, 0xFD, 0x03, 0xFF, 0xFF, 0xFF}, //U
{0xEF, 0xEF, 0x01, 0xEF, 0xEF, 0xFF, 0xFF, 0xFF}, //+
{0x01, 0xF7, 0x0F, 0xF7, 0x01, 0xFF, 0xFF, 0xFF}, //W
{0xFB, 0xFD, 0x7D, 0x03, 0x7F, 0xFF, 0xFF, 0xFF} //J
};
void delayms(int n) {
int i;
int j;
for (i = 0; i < n; i++) {
for (j = 0; j < 110; j++);
}
}
void main() {
int i = 0;
int j = 0;
int flag = 0;
int t = 25;
int time = 0;
P0 = 0xFF;
P1 = 0x00;
while (1) {
delayms(DELAY_1000MS);
for (j = 0; j < 8; j++) {
time = 100;
while (time-- > 0) {
for (i = 0; i < 8; i++) {
P0 = ~(0x01 << i);
P1 = Ledcode[j][i];
delayms(2);
P0 = 0x00;
P1 = 0xFF;
}
}
}
while (1) {
for (i = 0; i < 8; i++) {
if (flag == 1) {
for (t = 25; t > 0; t--) {
for (j = 0; j < 8; j++) {
P0 = ~(0x01 << j);
P1 = Ledcode[i][j];
delayms(25 - t);
P0 = 0x00;
P1 = 0xFF;
delayms(t);
}
}
flag = 0;
delayms(DELAY_1000MS);
} else if (flag == 0) {
for (t = 0; t < 25; t++) {
for (j = 0; j < 8; j++) {
P0 = ~(0x01 << j);
P1 = Ledcode[i][j];
delayms(25 - t);
P0 = 0x00;
P1 = 0xFF;
delayms(t);
}
}
flag = 1;
delayms(DELAY_1000MS);
}
}
if (i == 8) {
i = 0;
P0 = 0x00;
P1 = 0xFF;
break;
}
}
}
}
```
#include<reg51.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int sbit DQ=P3^7; sbit P2_0=P2^0; sbit k2=P2^2; sbit k4=P2^4; sbit k3=P2^3; uchar timp,F=0; float c; uchar a[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40}; uchar b[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef}; void delay5(uchar n) { do { _nop_(); _nop_(); _nop_(); n--; } while(n); } void init_DS18B20() { uchar x=0; DQ=0; delay5(120); DQ=1; delay5(16); delay5(80); } uchar readbyte() { uchar i=0; uchar date=0; for(i=8;i>0;i--) { DQ=0; delay5(1); DQ=1; date>>=1; if(DQ) date|=0x80; delay5(11); } return(date); } void writebyte(uchar dat) { uchar i=0; for(i=8;i>0;i--) { DQ=0; DQ=dat&0x01; delay5(12); DQ=1; dat>>=1; delay5(5); } } uchar retemp() { uchar a,b,tt; uint t; init_DS18B20(); writebyte(0xCC); writebyte(0x44); init_DS18B20(); writebyte(0xCC); writebyte(0xBE); a=readbyte(); b=readbyte(); t=b; t<<=8; t=t|a; if((t&0xf800)!=0xf800) { F=0; c=t*0.0625; tt=t*0.0625; timp=t*0.625-tt*10; } else { F=1; t=(~t)+1; c=t*0.0625; tt=t*0.0625; timp=t*0.625-tt*10; } return tt; } void main() { uchar i,temp; delay5(1000); while(1) { temp=retemp(); if(c>=25&&F==0) P2_0=0; else P2_0=1; for(i=0;i<15;i++) { k2=1;k3=1;k4=1; if(F==0) P0=a[temp/100]; else P0=a[10]; delay5(1000); // P2=0xfb;//11111011,0xfb k2=0;k3=1;k4=1; P0=a[temp%100/10]; delay5(1000); //P2=0xf7;//11110111,0xf7 k2=1;k3=0;k4=1; P0=b[temp%10]; delay5(1000); //P2=0xf3;//11110011,0xf3 k2=0;k3=0;k4=1; P0=a[timp]; delay5(1000); } if(c>=25&&F==0) P2_0=1; else P2_0=1; } }在这个代码的基础上利用串口把数据发送到电脑上的串口助手
好的,我帮您修改一下程序,添加串口通信代码,您可以将数据发送到电脑上的串口助手中:
```
#include<reg51.h>
#include<intrins.h>
#include<stdio.h>
#define uchar unsigned char
#define uint unsigned int
sbit DQ=P3^7;
sbit P2_0=P2^0;
sbit k2=P2^2;
sbit k4=P2^4;
sbit k3=P2^3;
uchar timp,F=0;
float c;
uchar a[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40};
uchar b[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef};
void delay5(uchar n)
{
do
{
_nop_();
_nop_();
_nop_();
n--;
} while(n);
}
void init_DS18B20()
{
uchar x=0;
DQ=0;
delay5(120);
DQ=1;
delay5(16);
delay5(80);
}
uchar readbyte()
{
uchar i=0;
uchar date=0;
for(i=8;i>0;i--)
{
DQ=0;
delay5(1);
DQ=1;
date>>=1;
if(DQ)
date|=0x80;
delay5(11);
}
return(date);
}
void writebyte(uchar dat)
{
uchar i=0;
for(i=8;i>0;i--)
{
DQ=0;
DQ=dat&0x01;
delay5(12);
DQ=1;
dat>>=1;
delay5(5);
}
}
uchar retemp()
{
uchar a,b,tt;
uint t;
init_DS18B20();
writebyte(0xCC);
writebyte(0x44);
init_DS18B20();
writebyte(0xCC);
writebyte(0xBE);
a=readbyte();
b=readbyte();
t=b;
t<<=8;
t=t|a;
if((t&0xf800)!=0xf800)
{
F=0;
c=t*0.0625;
tt=t*0.0625;
timp=t*0.625-tt*10;
}
else
{
F=1;
t=(~t)+1;
c=t*0.0625;
tt=t*0.0625;
timp=t*0.625-tt*10;
}
return tt;
}
void init_uart()
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
SCON=0x50;
TR1=1;
}
void send_data(uchar dat)
{
SBUF=dat;
while(!TI);
TI=0;
}
void main()
{
uchar i,temp;
delay5(1000);
init_uart(); //初始化串口
while(1)
{
temp=retemp();
if(c>=25&&F==0)
P2_0=0;
else
P2_0=1;
for(i=0;i<15;i++)
{
k2=1;k3=1;k4=1;
if(F==0)
P0=a[temp/100];
else
P0=a[10];
delay5(1000);
k2=0;k3=1;k4=1;
P0=a[temp%100/10];
delay5(1000);
k2=1;k3=0;k4=1;
P0=b[temp%10];
delay5(1000);
k2=0;k3=0;k4=1;
P0=a[timp];
delay5(1000);
}
if(c>=25&&F==0)
P2_0=1;
else
P2_0=1;
//将温度值发送到串口助手
printf("Temperature is: %.2f\r\n", c);
}
}
```
注意:这里添加了头文件 `stdio.h`,需要在编译器中设置支持此头文件。另外,串口助手的波特率需要与代码中的波特率一致,这里设置为 9600。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)