找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1664|回復: 5
打印 上一主題 下一主題
收起左側(cè)

遇到一個非常奇怪的C語言while循環(huán)問題

[復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:997026 發(fā)表于 2023-5-11 12:26 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
大家好

問題是:
1,我把 read_data_from_EEPROM();這個函數(shù)注釋掉,show_the_daojishi();這個顯示開機倒計時的函數(shù)就變卡死了。
而read_data_from_EEPROM();這個函數(shù)只是從外部EEPROM讀取保存的數(shù)據(jù),和show_the_daojishi();沒有任何關(guān)聯(lián),我不知道怎么就影響了?

2,我把read_data_from_EEPROM();注釋掉,專門來調(diào)試show_the_daojishi();這個函數(shù),試圖知道為什么顯示不正常的原因。
顯示不正常的主要現(xiàn)象是,數(shù)碼管數(shù)顯示停留在了4,然后就一直卡死在4這個數(shù)字不動。
我用調(diào)試器仿真了一下,發(fā)現(xiàn)daojishi_display_cnt這個變量在中斷中是正常自減的,最后也減到了0,然后停在0,但是show_the_daojishi();中的while循環(huán)并沒有退出循環(huán),實際此時daojishi_display_cnt已經(jīng)是0了,但是顯示上卡死在4一直不動,我加了一個變量get_the_step,仿真了下,發(fā)現(xiàn)get_the_step最終為1,說明循環(huán)只跑了一次就停了。start_the_bl這個變量的值也一直是0,說明根本沒往下跑,是卡死在while循環(huán)中,而且這個循環(huán)只跑了一次。

但daojishi_display_cnt明明已經(jīng)減到0了呀,說明中斷是沒問題的,那么為什么while沒有退出循環(huán),而且值循環(huán)了一次就卡死了呢?

雖然寫的程序也比較多了,但有時會遇到莫名其妙的問題,搞了好多天都沒找到原因?赡苁莻很簡單的問題,但是所謂當局者迷,旁觀者清,我入局太深也許看不到,希望各位大神幫我分析分析,不勝感激!

有如下C語言程序:

unsigned char  get_the_step=0; //記錄循環(huán)次數(shù)
unsigned char  start_the_bl=0;
unsigned char  daojishi_display_cnt=5; //開機倒計時變量,在中斷中自減
void show_the_daojishi();  //倒計時顯示
void Display_Write_OneData_with_Addr(unsigned char weima, unsigned char duanma); //數(shù)碼管顯示函數(shù)
unsigned char  table_duanma[10]={0x5f,0x06,0x6b,0x2f,0x36,0x3d,0x7d,0x07,0x7f,0x3f};  //段碼0~9
void read_data_from_EEPROM();  //讀取EEPROM中保存的值
void main_task_run();  //主任務

int main(void)
{
     read_data_from_EEPROM(); //如果注釋掉這個函數(shù),倒計時顯示不正常
     show_the_daojishi(); //5s倒計時顯示
     start_the_bl=1;

    while(1)
    {
          main_task_run();  //主任務運行
    }
}


void show_the_daojishi()
{
     while(daojishi_display_cnt !=0) //初值為5,在中斷中自減到0退出循環(huán)
     {
          get_the_step++;
          Display_Write_OneData_with_Addr(1, table_duanma[daojishi_display_cnt]); //顯示倒計時
     }
}


//中斷服務程序,1s進一次中斷
void TIM3_IRQHandler(void)
{
   if(TIM_GetITStatus(TIM3,TIM_IT_Update) != RESET)
    {
        TIM_ClearITPendingBit(TIM3,TIM_IT_Update);

        if(daojishi_display_cnt !=0)
        {
             daojishi_display_cnt--;
        }
}
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:1064118 發(fā)表于 2023-5-11 13:21 | 只看該作者
程序在主循環(huán)外邊,跑一次是對的
回復

使用道具 舉報

板凳
ID:997026 發(fā)表于 2023-5-11 13:31 | 只看該作者
zywng2153 發(fā)表于 2023-5-11 13:21
程序在主循環(huán)外邊,跑一次是對的

不至于吧,我這個循環(huán)是有條件的,中斷中計時5s才會減到0,不至于跑一遍阿
回復

使用道具 舉報

地板
ID:123289 發(fā)表于 2023-5-11 14:41 | 只看該作者
解決此類問題建議:
1、畫出程序流程圖
2、從邏輯上走通流程圖。
對照出現(xiàn)的問題,是否還能走通。
難免會深入到某【函數(shù)】內(nèi)部,但【函數(shù)】是借來的,不是自己寫的。就需要進入研究,如此才能將流程圖完善、完整、流通。
這樣所有的問題就通了。
回復

使用道具 舉報

5#
ID:353115 發(fā)表于 2023-5-11 16:20 | 只看該作者
daojishi_display_cnt要聲明成vu8,避免編譯器優(yōu)化
回復

使用道具 舉報

6#
ID:213173 發(fā)表于 2023-5-11 16:35 | 只看該作者
在編譯器里走單步看看
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表