HAL_Delay()能传入变量吗
时间: 2024-05-09 15:15:24 浏览: 52
HAL_Delay()函数的参数是一个常量,即需要延迟的毫秒数。如果需要传入变量作为延迟时间,可以使用标准库函数delay(),该函数的参数可以是任意整数类型。例如:
```c
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
void delay(unsigned int ms)
{
clock_t goal = ms + clock();
while (goal > clock());
}
int main()
{
int delay_time = 1000;
printf("Starting delay for %d milliseconds...\n", delay_time);
delay(delay_time);
printf("Delay completed!\n");
return 0;
}
```
在上述代码中,使用了标准库函数clock()获取当前时钟周期数,然后通过计算目标时钟周期数,实现了需要延迟的时间。
相关问题
#include "dht11.h" void Delay_us(uint16_t delay) { __HAL_TIM_DISABLE(&htim3); __HAL_TIM_SET_COUNTER(&htim3,0); __HAL_TIM_ENABLE(&htim3); uint16_t curCnt=0; while(1) { curCnt=__HAL_TIM_GET_COUNTER(&htim3); if(curCnt>=delay) break; } __HAL_TIM_DISABLE(&htim3); } void DHT11_OUT(void) { GPIO_InitTypeDef GPIO_InitStruct = {0}; GPIO_InitStruct.Pin = GPIO_PIN_8; GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; GPIO_InitStruct.Pull = GPIO_PULLUP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); } void DHT11_IN(void) { GPIO_InitTypeDef GPIO_InitStruct = {0}; GPIO_InitStruct.Pin = GPIO_PIN_8; GPIO_InitStruct.Mode = GPIO_MODE_INPUT; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); } void DHT11_Strat(void) { DHT11_OUT(); HAL_GPIO_WritePin(GPIOB,GPIO_PIN_8,GPIO_PIN_RESET); HAL_Delay(20); HAL_GPIO_WritePin(GPIOB,GPIO_PIN_8,GPIO_PIN_SET); Delay_us(30); } uint8_t DHT11_Check(void) { uint8_t retry = 0 ; DHT11_IN(); while(GPIO_PIN_SET == HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_8) && retry <100) { retry++; Delay_us(1);//1us } if(retry>=100) {return 1;} else retry = 0 ; while(GPIO_PIN_RESET == HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_8) && retry<100) { retry++; Delay_us(1);//1us } if(retry>=100) {return 1;} return 0 ; } uint8_t DHT11_Read_Bit(void) { uint8_t retry = 0 ; while(GPIO_PIN_SET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8) && retry <100) { retry++; Delay_us(1); } retry = 0 ; while(GPIO_PIN_RESET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8) && retry<100) { retry++; Delay_us(1); } Delay_us(40); if(GPIO_PIN_SET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8)) return 1; else return 0 ; } uint8_t DHT11_Read_Byte(void) { uint8_t i , dat ; dat = 0 ; for(i=0; i<8; i++) { dat <<= 1; dat |= DHT11_Read_Bit(); } return dat ; } uint8_t DHT11_Read_Data(uint8_t* temp , uint8_t* humi) { uint8_t buf[5]; uint8_t i; DHT11_Strat(); if(DHT11_Check() == 0) { for(i=0; i<5; i++) { buf[i] = DHT11_Read_Byte(); } if(buf[0]+buf[1]+buf[2]+buf[3] == buf[4]) { *humi = buf[0]; *temp = buf[2]; } }else return 1; return 0 ; } void func_1() { uint8_t temperature = 1 ; uint8_t humidity = 1; uint8_t aTXbuf[32] ; while(1){ DHT11_Read_Data(&temperature , &humidity); sprintf((char*)aTXbuf,"%d , %d %% \r\n" ,temperature ,humidity); HAL_UART_Transmit(&huart1, aTXbuf, strlen((const char*)aTXbuf), 200); HAL_Delay(5000); } } int temperature_humidity_device_control(protocol_package_t *pk) { printf("temperature_humidity_device_control\r\n"); if(pk->function == 0x16 && pk->data[0] == 0x00) { printf("temperature_humidity_device_control success\r\n"); uint8_t temperature = 1 ; uint8_t humidity = 1; uint8_t aTXbuf[32] ; //DHT11_Read_Data(&temperature , &humidity); pk->data[0] = 0x35; } return 0; }改错
在你提供的代码中,没有包含头文件 "main.h" 和 "stdio.h"。你需要添加这两个头文件到你的代码中,这样才能正确使用其中的函数和变量。
另外,你在调用 sprintf 函数时,第二个参数类型应该是 char*,而不是 uint8_t*。因此,你需要将 aTXbuf 声明为 char 类型数组,而不是 uint8_t 类型数组。同时,在使用 strlen 函数计算字符串长度时,应该传入一个 char* 类型的参数。
最后,你可以将 DHT11_Read_Data 函数的返回值直接返回,而不需要使用 if-else 语句判断后再返回。因为函数内部已经有了返回值,可以直接将其返回给调用者。
以下是修改后的代码:
```c
#include "main.h"
#include "stdio.h"
#include "dht11.h"
extern UART_HandleTypeDef huart1;
extern TIM_HandleTypeDef htim3;
void Delay_us(uint16_t delay) {
__HAL_TIM_DISABLE(&htim3);
__HAL_TIM_SET_COUNTER(&htim3,0);
__HAL_TIM_ENABLE(&htim3);
uint16_t curCnt=0;
while(1)
{
curCnt=__HAL_TIM_GET_COUNTER(&htim3);
if(curCnt>=delay)
break;
}
__HAL_TIM_DISABLE(&htim3);
}
void DHT11_OUT(void) {
GPIO_InitTypeDef GPIO_InitStruct = {0};
GPIO_InitStruct.Pin = GPIO_PIN_8;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Pull = GPIO_PULLUP;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
}
void DHT11_IN(void) {
GPIO_InitTypeDef GPIO_InitStruct = {0};
GPIO_InitStruct.Pin = GPIO_PIN_8;
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
}
void DHT11_Strat(void) {
DHT11_OUT();
HAL_GPIO_WritePin(GPIOB,GPIO_PIN_8,GPIO_PIN_RESET);
HAL_Delay(20);
HAL_GPIO_WritePin(GPIOB,GPIO_PIN_8,GPIO_PIN_SET);
Delay_us(30);
}
uint8_t DHT11_Check(void) {
uint8_t retry = 0 ;
DHT11_IN();
while(GPIO_PIN_SET == HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_8) && retry <100)
{
retry++;
Delay_us(1);//1us
}
if(retry>=100)
{return 1;}
else retry = 0 ;
while(GPIO_PIN_RESET == HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_8) && retry<100)
{
retry++;
Delay_us(1);//1us
}
if(retry>=100)
{return 1;}
return 0 ;
}
uint8_t DHT11_Read_Bit(void) {
uint8_t retry = 0 ;
while(GPIO_PIN_SET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8) && retry <100)
{
retry++;
Delay_us(1);
}
retry = 0 ;
while(GPIO_PIN_RESET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8) && retry<100)
{
retry++;
Delay_us(1);
}
Delay_us(40);
if(GPIO_PIN_SET==HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_8)) return 1;
else return 0 ;
}
uint8_t DHT11_Read_Byte(void) {
uint8_t i , dat ;
dat = 0 ;
for(i=0; i<8; i++)
{
dat <<= 1;
dat |= DHT11_Read_Bit();
}
return dat ;
}
uint8_t DHT11_Read_Data(uint8_t* temp , uint8_t* humi) {
uint8_t buf[5];
uint8_t i;
DHT11_Strat();
if(DHT11_Check() == 0)
{
for(i=0; i<5; i++)
{
buf[i] = DHT11_Read_Byte();
}
if(buf[0]+buf[1]+buf[2]+buf[3] == buf[4])
{
*humi = buf[0];
*temp = buf[2];
return 0;
}
}
return 1;
}
void func_1() {
uint8_t temperature = 1;
uint8_t humidity = 1;
char aTXbuf[32];
while(1){
DHT11_Read_Data(&temperature , &humidity);
sprintf(aTXbuf,"%d , %d %% \r\n" ,temperature ,humidity);
HAL_UART_Transmit(&huart1, (uint8_t*)aTXbuf, strlen(aTXbuf), 200);
HAL_Delay(5000);
}
}
int temperature_humidity_device_control(protocol_package_t *pk) {
printf("temperature_humidity_device_control\r\n");
if(pk->function == 0x16 && pk->data[0] == 0x00)
{
printf("temperature_humidity_device_control success\r\n");
uint8_t temperature = 1 ;
uint8_t humidity = 1;
char aTXbuf[32];
DHT11_Read_Data(&temperature , &humidity);
sprintf(aTXbuf,"%d , %d %% \r\n" ,temperature ,humidity);
strncpy((char*)pk->data, aTXbuf, strlen(aTXbuf));
pk->data_len = strlen(aTXbuf);
pk->data[0] = 0x35;
}
return 0;
}
```
#include "hal_defs.h" #include "hal_cc8051.h" #include "hal_int.h" #include "hal_mcu.h" #include "hal_board.h" #include "hal_led.h" #include "hal_rf.h" #include "basic_rf.h" #include "hal_uart.h" #include <stdio.h> #include <string.h> #include <stdarg.h> /*****点对点通讯地址设置******/ #define RF_CHANNEL 23 // 频道 11~26 #define PAN_ID 0xAA22 //网络id #define MY_ADDR 0xAAAA //本机模块地址 #define SEND_ADDR 0xBBBB //发送地址 #define LED1 P1_0 #define LED2 P1_1 /**************************************************/ static basicRfCfg_t basicRfConfig; // 无线RF初始化 void ConfigRf_Init(void) { basicRfConfig.panId = PAN_ID; basicRfConfig.channel = RF_CHANNEL; basicRfConfig.myAddr = MY_ADDR; basicRfConfig.ackRequest = TRUE; while(basicRfInit(&basicRfConfig) == FAILED); basicRfReceiveOn(); } void initIO(void) { P1SEL &=~0x03; P1DIR |=0x03; LED1=1; LED2=1; } float getTemperature(void) { signed short int value; ADCCON3=(0x3E); ADCCON1 |=0x30; ADCCON1 |=0x40; while(!(ADCCON1 & 0x80)); value |=((int)ADCH<<6); if(value<0) value=0; return value*0.06229-311.43; } void getTemperature1(void) { char z; float avgTemp; unsigned char output[]=""; while(1) { LED1=1; avgTemp=getTemperature(); for(z=0;z<64;z++) { avgTemp +=getTemperature(); avgTemp=avgTemp/2; } output[0]=(unsigned char)(avgTemp)/10 + 48; output[1]=(unsigned char)(avgTemp)%10 + 48; output[2]='\0'; } } /********************MAIN************************/ void main(void) { halBoardInit();//选手不得在此函数内添加代码 ConfigRf_Init();//选手不得在此函数内添加代码 initIO(); uint8 a[128],c[128],len,output; while(1) { /* user code start */ len=halUartRxLen(); if(len>=2) { a[0]=len; halUartRead(&a[1],len); basicRfSendPacket(SEND_ADDR,a,len+1); } if(basicRfPacketIsReady()) { basicRfReceive(c,128,NULL); halUartWrite(&c[1],c[0]); if(c[1]==0xaa) { if(c[2]==0x01) { LED1=~LED1; LED2=LED2; } else if(c[2]==0x02) { LED2=~LED2; LED1=LED1; } else if(c[2]==0x03) { getTemperature1(); UART0SendString(output); UART0SendString("℃\t\r\n"); LED1=0; delay(2000); } { } } } /* user code end */ } }
这段代码存在一些问题:
1. 在函数 `getTemperature1()` 中,无限循环导致后面的代码无法运行。
2. 在函数 `getTemperature1()` 中,将浮点数转换为字符串的代码是错误的,应该使用 `sprintf` 函数。
3. 在函数 `main()` 中,变量 `output` 没有被初始化,导致在调用 `UART0SendString` 函数时会出现错误。
4. 在函数 `main()` 中,存在一个多余的空代码块。
5. 在函数 `main()` 中,调用了 `delay` 函数,但是该函数的声明和实现都没有给出,需要添加。
6. 在函数 `main()` 中,对变量 `len` 的使用可能会出现错误,因为 `halUartRxLen` 函数返回的是 `uint16` 类型,而 `len` 的类型是 `uint8`。
7. 在函数 `main()` 中,调用 `halUartRead` 函数时,第三个参数应该是 `len` 而不是 `len+1`。
8. 在函数 `main()` 中,调用 `UART0SendString` 函数时,应该将要发送的字符串作为参数传入,而不是将未初始化的变量 `output` 作为参数传入。
9. 在函数 `main()` 中,没有对变量 `a`、`c`、`len`、`output` 进行初始化,需要在主函数开头进行初始化。
10. 函数调用之间的空格和缩进不一致,需要进行统一。
下面是修改后的代码:
阅读全文