sprintf(szVal, "%0.3f" , val); LCD_DisString((i%9)+1, 19, szVal); Pro_szUnit(DBData[i],i); if (isDraw == 1) val = LCD_BitModify(val,draw); ikey = Lcd_Recvfun2(); switch(ikey) { case LCD_KEY_UP: bit = 0; if (not == 2) { if (draw > page + 1 && draw <= line) draw = draw - 1; } break; case LCD_KEY_DOWN: bit = 0; if (not == 2) { if(draw < i) if (draw < line) draw = draw + 1; } break; case LCD_KEY_ADD: break; case LCD_KEY_DECREASE: break; case LCD_KEY_Left: if (not == 1) { change = 0; if(page < 9) continue; if(page >= 9) { page = page - 9; line = line - 9; } } break; case LCD_KEY_RIGHT: if (not == 1) { change = 0; if(line >= num) continue; if(page < num) { page = page + 9; line = line + 9; } } break; case LCD_KEY_ENTER: not = 2; bit = 0; break; case LCD_KEY_CANCEL: change = 0; if(not > 0) --not; draw = 0; if (not == 0) return; break; default: break; } } 这段代码在死循环中运行,其中的LCD_BitModify函数也有死循环,怎么使它们互不干扰(不使用线程)

时间: 2024-04-05 08:31:46 浏览: 14
可以使用时间片轮转的方式来解决这个问题。在主循环中设置一个计时器,每隔一定时间就切换到另一个函数的执行。具体的实现方式可以使用一个标志变量来表示当前应该执行的函数,然后在计时器中切换标志变量的值。这样就可以让两个函数轮流执行,而不会互相干扰。当然,这个方法需要注意时间片的设置,以保证两个函数的执行时间不会过长,否则会影响系统的响应速度。
相关问题

优化这段代码 sprintf(szVal, "%0.3f" , get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])); LCD_DisString((i%9)+1, 19, szVal); if (DBData[i] >= RT1064_YS_GL1 && DBData[i] <= RT1064_YS_FBS_JY) LCD_DisString((i%9)+1, 25, (char *)"S"); else if ((DBData[i] >= RT1064_DZ_GL1 && DBData[i] <= RT1064_DZ_I02) || ((DBData[i] >= RT1064_DZ_PHASE_I && DBData[i] <= RT1064_DZ_I0DLT) && DBData[i] != RT1064_DZ_YL_HAR && DBData[i] != RT1064_DZ_LMJ) || DBData[i] == RT1064_DZ_SD || DBData[i] == RT1064_DZ_I0HJS || DBData[i] == RT1064_DZ_FC_CHZ || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)|| DBData[i] == RT1064_DZ_FBS_OL) { LCD_DisString((i%9)+1, 25, (char *)"A"); } else if (DBData[i] == RT1064_DZ_LMJ || DBData[i] == RT1064_DZ_JC || DBData[i] == RT1064_DZ_GYJC) { LCD_DisString((i%9)+1, 25, (char *)"°"); } else if (DBData[i] == RT1064_DZ_YL_HAR) LCD_DisString((i%9)+1, 25, (char *)"%"); else if (DBData[i] == RT1064_DZ_IDS ||DBData[i] == RT1064_DZ_OPENCS || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)) { LCD_DisString((i%9)+1, 24, (char *)"次"); } else if (DBData[i] == RT1064_DZ_DP || DBData[i] == RT1064_DZ_GP) { LCD_DisString((i%9)+1, 25, (char *)"HZ"); } else LCD_DisString((i%9)+1, 25, (char *)"V"); if (not == 2) { if(draw == (i+1)) len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); }

可以尝试使用 switch-case 语句来优化这段代码,将每种情况分开处理,让代码更加清晰易懂。同时,可以考虑定义一些常量或枚举值来代表每种情况,避免在代码中出现过多的数字和字符串常量。例如: ```c++ switch (DBData[i]) { case RT1064_YS_GL1: case RT1064_YS_FBS_JY: LCD_DisString((i%9)+1, 25, (char *)"S"); break; case RT1064_DZ_GL1: case RT1064_DZ_I02: case RT1064_DZ_SD: case RT1064_DZ_I0HJS: case RT1064_DZ_FC_CHZ: case RT1064_DZ_I03: case RT1064_DZ_FBS_I0: case RT1064_DZ_FBS_OL: case RT1064_DZ_PHASE_I: case RT1064_DZ_I0DLT: if (DBData[i] != RT1064_DZ_YL_HAR && DBData[i] != RT1064_DZ_LMJ) { LCD_DisString((i%9)+1, 25, (char *)"A"); } break; case RT1064_DZ_LMJ: case RT1064_DZ_JC: case RT1064_DZ_GYJC: LCD_DisString((i%9)+1, 25, (char *)"°"); break; case RT1064_DZ_YL_HAR: LCD_DisString((i%9)+1, 25, (char *)"%"); break; case RT1064_DZ_IDS: case RT1064_DZ_OPENCS: if (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0) { LCD_DisString((i%9)+1, 24, (char *)"次"); } break; case RT1064_DZ_DP: case RT1064_DZ_GP: LCD_DisString((i%9)+1, 25, (char *)"HZ"); break; default: LCD_DisString((i%9)+1, 25, (char *)"V"); break; } if (not == 2 && draw == (i+1)) { len = LCD_BitNot(UNIT_PROTECT, UNIT_GAP_RT1064, gapid, DBData[i], i, bit); } ``` 另外,可以考虑将相同的代码逻辑提取出来,避免重复的代码出现。例如,多个情况下都需要将浮点数转换成字符串并输出,可以将这部分代码提取出来,避免重复编写: ```c++ char szVal[16]; sprintf(szVal, "%0.3f", get_ActionDZInfo_val(UNIT_GAP_RT1064, gapid, DBData[i])); LCD_DisString((i%9)+1, 19, szVal); ```

优化这段代码 if( DBData[i] >= RT1064KZZ_GL1_ALM && DBData[i] <= RT1064KZZ_KZHL && DBData[i] != RT1064KZZ_MODE && DBData[i] != RT1064KZZ_UAB_CH && DBData[i] != RT1064KZZ_UBC_CH && DBData[i] != RT1064KZZ_FBS && DBData[i] != RT1064KZZ_FBS_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) ); } else if(DBData[i] == RT1064KZZ_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) ); } else if (DBData[i] == RT1064KZZ_FBS || DBData[i] == RT1064KZZ_FBS_MODE ) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) ); } else if(DBData[i] == RT1064KZZ_UAB_CH || DBData[i] == RT1064KZZ_UBC_CH || DBData[i] == RT1064_DZ_CHZCS) { sprintf(szVal, "%0.f" , val); LCD_DisString((i%LISTOFFSET)+1, 19 , szVal); if(DBData[i] == RT1064_DZ_CHZCS) LCD_DisString((i%LISTOFFSET)+1, 24, (char *)"次"); if (isDraw == 1) len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); } else { sprintf(szVal, "%0.3f" , get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])); LCD_DisString((i%LISTOFFSET)+1, 19, szVal); if (DBData[i] >= RT1064_YS_GL1 && DBData[i] <= RT1064_YS_FBS_JY) LCD_DisString((i%9)+1, 25, (char *)"S"); else if ((DBData[i] >= RT1064_DZ_GL1 && DBData[i] <= RT1064_DZ_I02) || ((DBData[i] >= RT1064_DZ_PHASE_I && DBData[i] <= RT1064_DZ_I0DLT) && DBData[i] != RT1064_DZ_YL_HAR && DBData[i] != RT1064_DZ_LMJ) || DBData[i] == RT1064_DZ_SD || DBData[i] == RT1064_DZ_I0HJS || DBData[i] == RT1064_DZ_FC_CHZ || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)|| DBData[i] == RT1064_DZ_FBS_OL) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"A"); } else if (DBData[i] == RT1064_DZ_LMJ || DBData[i] == RT1064_DZ_JC || DBData[i] == RT1064_DZ_GYJC) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"°"); } else if (DBData[i] == RT1064_DZ_YL_HAR) LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"%"); else if (DBData[i] == RT1064_DZ_IDS ||DBData[i] == RT1064_DZ_OPENCS || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)) { LCD_DisString((i%LISTOFFSET)+1, 24, (char *)"次"); } else if (DBData[i] == RT1064_DZ_DP || DBData[i] == RT1064_DZ_GP) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"HZ"); } else LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"V"); if (isDraw == 1)len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); }

这段代码可以优化的地方比较多,建议按照以下几个方面进行调整: 1. 将重复的代码片段提取出来,封装成函数,提高代码复用性和可读性; 2. 尽可能地使用 switch-case 语句替换 if-else 语句,提高代码执行效率; 3. 对于需要频繁操作的字符串拼接操作,可以使用 sprintf 函数来代替,提高代码执行效率。 下面是一个可能的优化版本: ```c void draw_LCD(int i, int isDraw, float val, int gapid, int bit) { char szVal[10]; switch (DBData[i]) { case RT1064KZZ_MODE: if (isDraw) { LCD_DisString_Not((i % LISTOFFSET) + 1, 20, (char *)ModeName[(int)val]); } else { LCD_DisString((i % LISTOFFSET) + 1, 20, (char *)ModeName[(int)val]); } break; case RT1064KZZ_FBS: case RT1064KZZ_FBS_MODE: if (isDraw) { LCD_DisString_Not((i % LISTOFFSET) + 1, 20, (char *)FBS_NAME[(int)val]); } else { LCD_DisString((i % LISTOFFSET) + 1, 20, (char *)FBS_NAME[(int)val]); } break; case RT1064KZZ_UAB_CH: case RT1064KZZ_UBC_CH: case RT1064_DZ_CHZCS: sprintf(szVal, "%0.f", val); LCD_DisString((i % LISTOFFSET) + 1, 19, szVal); if (DBData[i] == RT1064_DZ_CHZCS) { LCD_DisString((i % LISTOFFSET) + 1, 24, (char *)"次"); } if (isDraw) { LCD_BitNot(UNIT_PROTECT, UNIT_GAP_RT1064, gapid, DBData[i], i, bit); } break; default: sprintf(szVal, "%0.3f", get_ActionDZInfo_val(UNIT_GAP_RT1064, gapid, DBData[i])); LCD_DisString((i % LISTOFFSET) + 1, 19, szVal); if (DBData[i] >= RT1064_YS_GL1 && DBData[i] <= RT1064_YS_FBS_JY) { LCD_DisString((i % 9) + 1, 25, (char *)"S"); } else if ((DBData[i] >= RT1064_DZ_GL1 && DBData[i] <= RT1064_DZ_I02) || ((DBData[i] >= RT1064_DZ_PHASE_I && DBData[i] <= RT1064_DZ_I0DLT) && DBData[i] != RT1064_DZ_YL_HAR && DBData[i] != RT1064_DZ_LMJ) || DBData[i] == RT1064_DZ_SD || DBData[i] == RT1064_DZ_I0HJS || DBData[i] == RT1064_DZ_FC_CHZ || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0) || DBData[i] == RT1064_DZ_FBS_OL) { LCD_DisString((i % LISTOFFSET) + 1, 25, (char *)"A"); } else if (DBData[i] == RT1064_DZ_LMJ || DBData[i] == RT1064_DZ_JC || DBData[i] == RT1064_DZ_GYJC) { LCD_DisString((i % LISTOFFSET) + 1, 25, (char *)"°"); } else if (DBData[i] == RT1064_DZ_YL_HAR) { LCD_DisString((i % LISTOFFSET) + 1, 25, (char *)"%"); } else if (DBData[i] == RT1064_DZ_IDS || DBData[i] == RT1064_DZ_OPENCS || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)) { LCD_DisString((i % LISTOFFSET) + 1, 24, (char *)"次"); } else if (DBData[i] == RT1064_DZ_DP || DBData[i] == RT1064_DZ_GP) { LCD_DisString((i % LISTOFFSET) + 1, 25, (char *)"HZ"); } else { LCD_DisString((i % LISTOFFSET) + 1, 25, (char *)"V"); } if (isDraw) { LCD_BitNot(UNIT_PROTECT, UNIT_GAP_RT1064, gapid, DBData[i], i, bit); } break; } } ``` 调用方式如下: ```c for (int i = 0; i < DBData.size(); i++) { if (DBData[i] >= RT1064KZZ_GL1_ALM && DBData[i] <= RT1064KZZ_KZHL && DBData[i] != RT1064KZZ_MODE && DBData[i] != RT1064KZZ_UAB_CH && DBData[i] != RT1064KZZ_UBC_CH && DBData[i] != RT1064KZZ_FBS && DBData[i] != RT1064KZZ_FBS_MODE) { draw_LCD(i, isDraw, val, gapid, bit); } else { draw_LCD(i, isDraw, val, gapid, bit); } } ```

相关推荐

优化这段代码 if( DBData[i] >= RT1064KZZ_GL1_ALM && DBData[i] <= RT1064KZZ_KZHL && DBData[i] != RT1064KZZ_MODE && DBData[i] != RT1064KZZ_UAB_CH && DBData[i] != RT1064KZZ_UBC_CH && DBData[i] != RT1064KZZ_FBS && DBData[i] != RT1064KZZ_FBS_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) ); } else if(DBData[i] == RT1064KZZ_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) ); } else if (DBData[i] == RT1064KZZ_FBS || DBData[i] == RT1064KZZ_FBS_MODE ) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) ); } else if(DBData[i] == RT1064KZZ_UAB_CH || DBData[i] == RT1064KZZ_UBC_CH || DBData[i] == RT1064_DZ_CHZCS) { sprintf(szVal, "%0.f" , val); LCD_DisString((i%LISTOFFSET)+1, 19 , szVal); if(DBData[i] == RT1064_DZ_CHZCS) LCD_DisString((i%LISTOFFSET)+1, 24, (char *)"次"); if (isDraw == 1) len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); } else { sprintf(szVal, "%0.3f" , get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])); LCD_DisString((i%LISTOFFSET)+1, 19, szVal); if (DBData[i] >= RT1064_YS_GL1 && DBData[i] <= RT1064_YS_FBS_JY) LCD_DisString((i%9)+1, 25, (char *)"S"); else if ((DBData[i] >= RT1064_DZ_GL1 && DBData[i] <= RT1064_DZ_I02) || ((DBData[i] >= RT1064_DZ_PHASE_I && DBData[i] <= RT1064_DZ_I0DLT) && DBData[i] != RT1064_DZ_YL_HAR && DBData[i] != RT1064_DZ_LMJ) || DBData[i] == RT1064_DZ_SD || DBData[i] == RT1064_DZ_I0HJS || DBData[i] == RT1064_DZ_FC_CHZ || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)|| DBData[i] == RT1064_DZ_FBS_OL) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"A"); } else if (DBData[i] == RT1064_DZ_LMJ || DBData[i] == RT1064_DZ_JC || DBData[i] == RT1064_DZ_GYJC) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"°"); } else if (DBData[i] == RT1064_DZ_YL_HAR) LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"%"); else if (DBData[i] == RT1064_DZ_IDS ||DBData[i] == RT1064_DZ_OPENCS || (DBData[i] >= RT1064_DZ_I03 && DBData[i] <= RT1064_DZ_FBS_I0)) { LCD_DisString((i%LISTOFFSET)+1, 24, (char *)"次"); } else if (DBData[i] == RT1064_DZ_DP || DBData[i] == RT1064_DZ_GP) { LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"HZ"); } else LCD_DisString((i%LISTOFFSET)+1, 25, (char *)"V"); if (isDraw == 1)len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); }

优化这段代码 if(i >= COMMS_NET_TOTALSUM) break; memset(szVal, 0, sizeof(szVal)); sprintf(szVal, "%s", gRunPara.COMMS_NetInfo[netid][i].szName); LCD_DisString((i%9)+1, 0, szVal); if( ((i >= COM_NET_PCL) && (i <= COM_NET_DIR)) || ((i >= COM_NET_YXM) && (i <= COM_NET_SNTP)) || (i == COM_NET_SYNCTM)) { if( i == COM_NET_PCL ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdComPcl[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if(((i > COM_NET_PCL) && (i < COM_NET_DIR)) || i == COM_NET_SNTP ) { unsigned char bytesforIP[4]; if (i == COM_NET_IP) { (float)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(buf,"%d%d%d.%d%d%d.%d%d%d.%d%d%d",bytesforIP[0]/100,bytesforIP[0]%100/10,bytesforIP[0]%10,bytesforIP[1]/100,bytesforIP[1]%100/10,bytesforIP[1]%10, bytesforIP[2]/100,bytesforIP[2]%100/10,bytesforIP[2]%10,bytesforIP[3]/100,bytesforIP[3]%100/10,bytesforIP[3]%10); LCD_DisString((i%9)+1, 10, buf); len = strlen(buf); if (not == 2) Lcd_IP_Not(netid,i,j,len,buf); } else { if (i == COM_NET_SNTP ) { (float)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(szVal,"%d.%d.%d.%d",bytesforIP[0],bytesforIP[1],bytesforIP[2],bytesforIP[3]); LCD_DisString((i%9)+1, 14, szVal); } else { (float)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(szVal,"%d.%d.%d.%d",bytesforIP[0],bytesforIP[1],bytesforIP[2],bytesforIP[3]); LCD_DisString((i%9)+1, 10, szVal); } } } else if( i == COM_NET_DIR ) { LCD_DisString((i%9)+1, 16, (char *)gcszStateName1[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_YXM || i == COM_NET_YKM) { LCD_DisString((i%9)+1, 16, (char *)gcszPoint[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_YCM ) { LCD_DisString((i%9)+1, 16, (char *)gcszData[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_JM ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdJmMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_AREA ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdSynctmMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_SYNCTM ) { LCD_DisString((i%9)+1, 18, (char *)gcszLcdRSMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } } else { if (i >= 12 && i <= 14) { sprintf(szVal, "%.0f", gRunPara.COMMS_NetInfo[netid][i].val); LCD_DisString((i%9)+1, 16, szVal); } else { sprintf(szVal, "%.0f", gRunPara.COMMS_NetInfo[netid][i].val); LCD_DisString((i%9)+1, 18, szVal); } }

优化这段代码 if(i >= COMMS_NET_TOTALSUM) break; memset(szVal, 0, sizeof(szVal)); sprintf(szVal, "%s", gRunPara.COMMS_NetInfo[netid][i].szName); LCD_DisString((i%9)+1, 0, szVal); if( ((i >= COM_NET_PCL) && (i <= COM_NET_DIR)) || ((i >= COM_NET_YXM) && (i <= COM_NET_SNTP)) || (i == COM_NET_SYNCTM)) { if( i == COM_NET_PCL ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdComPcl[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if(((i > COM_NET_PCL) && (i < COM_NET_DIR)) || i == COM_NET_SNTP ) { unsigned char bytesforIP[4]; if (i == COM_NET_IP) { *(float*)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(buf,"%d%d%d.%d%d%d.%d%d%d.%d%d%d",bytesforIP[0]/100,bytesforIP[0]%100/10,bytesforIP[0]%10,bytesforIP[1]/100,bytesforIP[1]%100/10,bytesforIP[1]%10, bytesforIP[2]/100,bytesforIP[2]%100/10,bytesforIP[2]%10,bytesforIP[3]/100,bytesforIP[3]%100/10,bytesforIP[3]%10); LCD_DisString((i%9)+1, 10, buf); len = strlen(buf); if (not == 2) Lcd_IP_Not(netid,i,j,len,buf); } else { if (i == COM_NET_SNTP ) { *(float*)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(szVal,"%d.%d.%d.%d",bytesforIP[0],bytesforIP[1],bytesforIP[2],bytesforIP[3]); LCD_DisString((i%9)+1, 14, szVal); } else { *(float*)bytesforIP = gRunPara.COMMS_NetInfo[netid][i].val; sprintf(szVal,"%d.%d.%d.%d",bytesforIP[0],bytesforIP[1],bytesforIP[2],bytesforIP[3]); LCD_DisString((i%9)+1, 10, szVal); } } } else if( i == COM_NET_DIR ) { LCD_DisString((i%9)+1, 16, (char *)gcszStateName1[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_YXM || i == COM_NET_YKM) { LCD_DisString((i%9)+1, 16, (char *)gcszPoint[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_YCM ) { LCD_DisString((i%9)+1, 16, (char *)gcszData[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_JM ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdJmMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_AREA ) { LCD_DisString((i%9)+1, 16, (char *)gcszLcdSynctmMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } else if( i == COM_NET_SYNCTM ) { LCD_DisString((i%9)+1, 18, (char *)gcszLcdRSMode[(int)gRunPara.COMMS_NetInfo[netid][i].val]); } } else { if (i >= 12 && i <= 14) { sprintf(szVal, "%.0f", gRunPara.COMMS_NetInfo[netid][i].val); LCD_DisString((i%9)+1, 16, szVal); } else { sprintf(szVal, "%.0f", gRunPara.COMMS_NetInfo[netid][i].val); LCD_DisString((i%9)+1, 18, szVal); } }

优化这段代码 if(i > num - 1) break; isDraw = (not == 2 && (draw == i+1)); if (DBData[i] != RT1064_YS_YYDD && DBData[i] != RT1064KZZ_FC_CHZ ) LCD_DisString((i%LISTOFFSET)+1, 0, gRunPara.gap_ActionDZInfo[gapid][DBData[i]].szName); if (DBData[i] == RT1064KZZ_FC_CHZ) LCD_DisString((i%LISTOFFSET)+1, 0, (char *)"大电流闭锁重合闸"); if (DBData[i] == RT1064_YS_YYDD) LCD_DisString((i%LISTOFFSET)+1, 0, (char *)"重合闸检有压时间"); val = get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i]); if( DBData[i] >= RT1064KZZ_GL1_ALM && DBData[i] <= RT1064KZZ_KZHL && DBData[i] != RT1064KZZ_MODE && DBData[i] != RT1064KZZ_UAB_CH && DBData[i] != RT1064KZZ_UBC_CH && DBData[i] != RT1064KZZ_FBS && DBData[i] != RT1064KZZ_FBS_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)gcszOnOff[(int)val]) ); } else if(DBData[i] == RT1064KZZ_MODE) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)ModeName[(int)val]) ); } else if (DBData[i] == RT1064KZZ_FBS || DBData[i] == RT1064KZZ_FBS_MODE ) { (isDraw ? LCD_DisString_Not((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) : LCD_DisString((i%LISTOFFSET)+1, 20,(char *)FBS_NAME[(int)val]) ); } else if(DBData[i] == RT1064KZZ_UAB_CH || DBData[i] == RT1064KZZ_UBC_CH || DBData[i] == RT1064_DZ_CHZCS) { sprintf(szVal, "%0.f" , val); LCD_DisString((i%LISTOFFSET)+1, 19 , szVal); if(DBData[i] == RT1064_DZ_CHZCS) LCD_DisString((i%LISTOFFSET)+1, 24, (char *)"次"); if (isDraw == 1) len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); }

优化这段代码 if( DBData[i] >= RT1064KZZ_GL1_ALM && DBData[i] <= RT1064KZZ_KZHL && DBData[i] != RT1064KZZ_MODE && DBData[i] != RT1064KZZ_UAB_CH && DBData[i] != RT1064KZZ_UBC_CH && DBData[i] != RT1064KZZ_FBS && DBData[i] != RT1064KZZ_FBS_MODE) { LCD_DisString((i%9)+1, 20, (char *)gcszOnOff[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); if (not == 2) { if(draw == (i+1)) { LCD_DisString_Not((i%9)+1, 20, (char *)gcszOnOff[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); } } } else if(DBData[i] == RT1064KZZ_MODE) { LCD_DisString((i%9)+1, 20, (char *)ModeName[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); if (not == 2) { if(draw == (i+1)) { LCD_DisString_Not((i%9)+1, 20, (char *)ModeName[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); } } } else if (DBData[i] == RT1064KZZ_FBS || DBData[i] == RT1064KZZ_FBS_MODE ) { if (DBData[i] == RT1064KZZ_FBS) { LCD_DisString((i%9)+1, 20, (char *)FBS_NAME[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); if (not == 2) { if(draw == (i+1)) { LCD_DisString_Not((i%9)+1, 20, (char *)FBS_NAME[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); } } } else if(DBData[i] == RT1064KZZ_FBS_MODE ) { LCD_DisString((i%9)+1, 20, (char *)FBS_MODE_NAME[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); if (not == 2) { if(draw == (i+1)) { LCD_DisString_Not((i%9)+1, 20, (char *)FBS_MODE_NAME[(int)get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])]); } } } } else if(DBData[i] == RT1064KZZ_UAB_CH || DBData[i] == RT1064KZZ_UBC_CH || DBData[i] == RT1064_DZ_CHZCS) { sprintf(szVal, "%0.f" , get_ActionDZInfo_val(UNIT_GAP_RT1064,gapid,DBData[i])); LCD_DisString((i%9)+1, 19 , szVal); if(DBData[i] == RT1064_DZ_CHZCS) LCD_DisString((i%9)+1, 24, (char *)"次"); if (not == 2) { if(draw == (i+1)) { len = LCD_BitNot(UNIT_PROTECT,UNIT_GAP_RT1064,gapid,DBData[i],i,bit); } } }

最新推荐

recommend-type

什么是yolov10,简单举例.md

YOLOv10是一种目标检测算法,是YOLO系列算法的第10个版本。YOLO(You Only Look Once)是一种快速的实时目标检测算法,能够在一张图像中同时检测出多个目标。
recommend-type

shufflenet模型-图像分类算法对动态表情分类识别-不含数据集图片-含逐行注释和说明文档.zip

shufflenet模型_图像分类算法对动态表情分类识别-不含数据集图片-含逐行注释和说明文档 本代码是基于python pytorch环境安装的。 下载本代码后,有个环境安装的requirement.txt文本 如果有环境安装不会的,可自行网上搜索如何安装python和pytorch,这些环境安装都是有很多教程的,简单的 环境需要自行安装,推荐安装anaconda然后再里面推荐安装python3.7或3.8的版本,pytorch推荐安装1.7.1或1.8.1版本 首先是代码的整体介绍 总共是3个py文件,十分的简便 且代码里面的每一行都是含有中文注释的,小白也能看懂代码 然后是关于数据集的介绍。 本代码是不含数据集图片的,下载本代码后需要自行搜集图片放到对应的文件夹下即可 在数据集文件夹下是我们的各个类别,这个类别不是固定的,可自行创建文件夹增加分类数据集 需要我们往每个文件夹下搜集来图片放到对应文件夹下,每个对应的文件夹里面也有一张提示图,提示图片放的位置 然后我们需要将搜集来的图片,直接放到对应的文件夹下,就可以对代码进行训练了。 运行01生成txt.py,
recommend-type

该项目存放基于Cesium的三维GIS平台开发中各种实践程序、截图、总结等,其中程序目录结构

"GIS" 通常指的是 地理信息系统(Geographic Information System)。它是一种特定的空间信息系统,用于捕获、存储、管理、分析、查询和显示与地理空间相关的数据。GIS 是一种多学科交叉的产物,涉及地理学、地图学、遥感技术、计算机科学等多个领域。 GIS 的主要特点和功能包括: 空间数据管理:GIS 能够存储和管理地理空间数据,这些数据可以是点、线、面等矢量数据,也可以是栅格数据(如卫星图像或航空照片)。 空间分析:GIS 提供了一系列的空间分析工具,用于查询、量测、叠加分析、缓冲区分析、网络分析等。 可视化:GIS 能够将地理空间数据以地图、图表等形式展示出来,帮助用户更直观地理解和分析数据。 数据输入与输出:GIS 支持多种数据格式的输入和输出,包括数字线划图(DLG)、数字高程模型(DEM)、数字栅格图(DRG)等。 决策支持:GIS 可以为城市规划、环境监测、灾害管理、交通规划等领域提供决策支持。 随着技术的发展,GIS 已经广泛应用于各个领域,成为现代社会不可或缺的一部分。同时,GIS 也在不断地发展和完善,以适应更多领域的需求。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

深入了解MATLAB开根号的最新研究和应用:获取开根号领域的最新动态

![matlab开根号](https://www.mathworks.com/discovery/image-segmentation/_jcr_content/mainParsys3/discoverysubsection_1185333930/mainParsys3/image_copy.adapt.full.medium.jpg/1712813808277.jpg) # 1. MATLAB开根号的理论基础 开根号运算在数学和科学计算中无处不在。在MATLAB中,开根号可以通过多种函数实现,包括`sqrt()`和`nthroot()`。`sqrt()`函数用于计算正实数的平方根,而`nt
recommend-type

react的函数组件的使用

React 的函数组件是一种简单的组件类型,用于定义无状态或者只读组件。 它们通常接受一个 props 对象作为参数并返回一个 React 元素。 函数组件的优点是代码简洁、易于测试和重用,并且它们使 React 应用程序的性能更加出色。 您可以使用函数组件来呈现简单的 UI 组件,例如按钮、菜单、标签或其他部件。 您还可以将它们与 React 中的其他组件类型(如类组件或 Hooks)结合使用,以实现更复杂的 UI 交互和功能。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

解决MATLAB开根号常见问题:提供开根号运算的解决方案

![解决MATLAB开根号常见问题:提供开根号运算的解决方案](https://img-blog.csdnimg.cn/d939d1781acc404d8c826e8af207e68f.png) # 1. MATLAB开根号运算基础** MATLAB开根号运算用于计算一个数的平方根。其语法为: ``` y = sqrt(x) ``` 其中: * `x`:要开根号的数或数组 * `y`:开根号的结果 开根号运算的输入可以是实数、复数、矩阵或数组。对于实数,开根号运算返回一个非负实数。对于复数,开根号运算返回一个复数。对于矩阵或数组,开根号运算逐元素执行,对每个元素进行开根号运算。 #