void UartSendString(char *Data, int len) { uint i; for(i=0; i<len; i++) { U0DBUF = *Data++; while(UTX0IF == 0); UTX0IF = 0; } }
时间: 2024-03-18 11:44:54 浏览: 11
这是一个发送字符串的函数,其中使用了8051单片机的UART模块进行数据发送。函数参数包括要发送的字符串指针和字符串长度。函数内部使用了一个for循环,依次发送字符串中的每个字符。具体实现是通过将字符写入UART数据寄存器U0DBUF,并在发送完成后等待发送完成标志UTX0IF置位,然后清除该标志,以确保数据已经成功发送出去。
相关问题
int temperature_humidity_device_control(protocol_package_t *pk) //void func_1() { int i = 0; // for(i = 0; i < 4; ++i){ uint8_t temperature = 1 ; uint8_t humidity = 1; uint8_t aTXbuf[32] ; printf("TEM_HUM_device\n"); if(pk->function == 0x16 && pk->data[0] == 0x0){ // while(1){ for(i = 0; i < 4; ++i){ printf("TEM_HUM_SUCCESS\n"); 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(2000); } pk->len = 0x4; pk->data[0] = 0x35; pk->data[1] = temperature; pk->data[2] = humidity; }else{ printf("TEM_HUM_ERROR\n"); pk->data[0] = 0x36; } //} return 0; }改错
这段代码有一些问题:
1. 在函数开头的注释中出现了一个未定义的函数名 "func_1()",如果不需要这个函数,建议将这个注释删除。
2. 变量 i 在 for 循环中被定义,但是在循环外也被定义了一次,这样会导致编译错误。建议将 for 循环中的 i 声明放到循环外。
3. 在函数中有一个 while(1) 的注释,但是没有相应的代码实现,如果不需要这个死循环,建议将这个注释删除。
4. 在 DHT11_Read_Data 函数中读取的温度和湿度值没有进行错误检查,建议在函数调用之后对返回值进行检查,如果返回错误,可以设置一个默认值或者进行其他的错误处理。
修改后的代码如下所示:
```
int temperature_humidity_device_control(protocol_package_t *pk) {
uint8_t temperature = 0;
uint8_t humidity = 0;
uint8_t aTXbuf[32];
printf("TEM_HUM_device\n");
if (pk->function == 0x16 && pk->data[0] == 0x0) {
for (int i = 0; i < 4; ++i) {
printf("TEM_HUM_SUCCESS\n");
if (DHT11_Read_Data(&temperature, &humidity) != SUCCESS) {
temperature = 0;
humidity = 0;
}
sprintf((char*)aTXbuf, "%d , %d %% \r\n", temperature, humidity);
HAL_UART_Transmit(&huart1, aTXbuf, strlen((const char*)aTXbuf), 200);
HAL_Delay(2000);
}
pk->len = 0x4;
pk->data[0] = 0x35;
pk->data[1] = temperature;
pk->data[2] = humidity;
} else {
printf("TEM_HUM_ERROR\n");
pk->data[0] = 0x36;
}
return 0;
}
```
int generate_frag_data(void){ #if !defined JF return 0; #else int index=0; int data_len=PDU_FRAG_DATA_LEN; memset(frag_data_buf,0,sizeof(frag_data_buf)); MN_printf(0, "generate_frag_data frag_num=%d\r\n",frag_num); #ifdef FIRST_FRAG_ADD_EXTRA_DATA if(FRAG_NUM_START==frag_num){ uint8_t max_min_value[2]; get_sample_data_max_min_value(max_min_value); float v_min=computeMvScale_f(max_min_value[1]); float v_max=1600;//computeMvScale_f(max_min_value[0]); uint8_t * v_max_fp=(uint8_t *)&v_max; uint8_t * v_min_fp=(uint8_t *)&v_min; index=first_frag_add_extra_data((uint8_t *)frag_data_buf,v_min_fp,v_max_fp); data_len+=FIRST_FRAG_EXTRA_DATA_LEN; } #endif int frag_src_data_num= MAX_SAMP_DATA_LEN * MAX_SAMP_BUF_NUM / FRAG_TOTAL_NUM; for(int i=0;i<frag_src_data_num;i++){ int frag_src_data_index= frag_src_data_num*(frag_num-1)+i; int sdata_item_index= frag_src_data_index/MAX_SAMP_DATA_LEN; int sdata_index=frag_src_data_index % MAX_SAMP_DATA_LEN; uint8_t data=sample_jufang_buf.sdata_item[sdata_item_index].sdata[sdata_index]; float data_f=computeMvScale_f(data); memcpy(&frag_data_buf[index+i*4],(uint8_t *)&data_f,4); /*if(i%250==0){ MN_printf(0, "generate_frag_data i=%d\r\n",i); MN_printf(0, "generate_frag_data frag_src_data_num=%d\r\n",frag_src_data_num); MN_printf(0, "generate_frag_data frag_src_data_index=%d\r\n",frag_src_data_index); MN_printf(0, "generate_frag_data sdata_item_index=%d\r\n",sdata_item_index); MN_printf(0, "generate_frag_data sdata_index=%d\r\n",sdata_index); MN_printf(0, "generate_frag_data index+i*4=%d\r\n",index+i*4); MN_printf(0, "generate_frag_data data=%2x\r\n",data); MN_printf(0, "generate_frag_data frag_data_buf[index+i*4]=%2x\r\n",frag_data_buf[index+i*4]); MN_printf(0, "generate_frag_data frag_data_buf[index+i*4+1]=%2x\r\n",frag_data_buf[index+i*4+1]); MN_printf(0, "generate_frag_data frag_data_buf[index+i*4+2]=%2x\r\n",frag_data_buf[index+i*4+2]); MN_printf(0, "generate_frag_data frag_data_buf[index+i*4+3]=%2x\r\n",frag_data_buf[index+i*4+3]); #if defined SAMPLE_DATA_FLOAT_VALUE_UPLOAD float fReceive; *((char *)(&fReceive)) = frag_data_buf[index+i*4]; *((char *)(&fReceive) + 1) = frag_data_buf[index+i*4+1]; *((char *)(&fReceive) + 2) = frag_data_buf[index+i*4+2]; *((char *)(&fReceive) + 3) = frag_data_buf[index+i*4+3]; uint32_t a = (uint32_t)(fReceive*1000); MN_printf(0, "sample_data_float_value=%ld\r\n",a); #endif }*/ } return data_len; #endif }
这段代码是用于生成分段数据的,它会根据不同的条件生成不同的数据。其中,宏定义 JF 的值决定了函数的返回值,如果 JF 未定义,则返回 0,否则执行后续操作。变量 frag_num 表示分段数据的编号,变量 frag_src_data_num 表示每个分段数据包含的原始数据个数。函数先清空了一个名为 frag_data_buf 的缓冲区,然后逐个读取原始数据,将其转换为浮点数并存储到缓冲区中,最终返回生成的数据长度。其中,还有一些条件编译的代码块,用于在特定情况下添加额外的数据。