解释一下这串代码void delay_18B20(uint i) { while(i--); } void Init_DS18B20(void) { uchar x=0; DQ =1; delay_18B20(8); DQ =0; delay_18B20(80); DQ =1; delay_18B20(14); x=DQ; delay_18B20(20); } uchar ReadOneChar(void) { unsigned char i=0; unsigned char dat0 = 0; for(i=8;i>0;i--){ DQ= 0; dat0>>=1; DQ= 1; if(DQ) dat0|=0x80; delay_18B20(4); } return(dat0); }
时间: 2024-02-10 18:28:43 浏览: 161
这段代码是用来操作DS18B20温度传感器的函数。
- `delay_18B20`函数用于实现延时功能,参数`i`表示延时的次数。函数内部使用了一个简单的`while`循环,通过不断递减`i`的值来实现延时。
- `Init_DS18B20`函数用于初始化DS18B20温度传感器。在初始化过程中,通过设置`DQ`引脚的电平和调用`delay_18B20`函数来实现相应的延时。具体的初始化步骤包括:
- 将`DQ`引脚设置为高电平。
- 延时一段时间(约8微秒)。
- 将`DQ`引脚设置为低电平。
- 延时一段时间(约80微秒)。
- 将`DQ`引脚设置为高电平。
- 延时一段时间(约14微秒)。
- 读取`DQ`引脚的电平,并将结果保存在变量`x`中。
- 延时一段时间(约20微秒)。
- `ReadOneChar`函数用于从DS18B20温度传感器读取一个字节的数据。在读取过程中,通过控制`DQ`引脚的电平和调用`delay_18B20`函数来实现相应的延时。具体的读取步骤包括:
- 使用一个循环,循环8次,每次读取一个位。
- 将`DQ`引脚设置为低电平,用于发送读取命令。
- 将要读取的数据位右移一位。
- 将`DQ`引脚设置为高电平,用于读取数据位的值。
- 如果`DQ`引脚为高电平,则将要读取的数据位的最高位设为1;否则设为0。
- 延时一段时间(约4微秒)。
- 返回读取到的数据字节。
需要注意的是,代码中使用了一些未定义的类型和变量,如`uchar`、`DQ`,这些可能是用户自定义的类型或者来自其他地方的定义。在理解代码功能时,需要对这些类型和变量进行适当的替换或定义。同时,还需要确保正确地连接和配置DS18B20温度传感器以及相应的引脚。
阅读全文