STC8H1K08是1T單片機(1個時鐘周期執行1條指令),而傳統51是12T(12個時鐘周期執行1條指令)。這導致原有代碼中的時序邏輯(延時、定時器)在STC8H上運行速度快了12倍,無法正確解碼315MHz信號。 解決方案: 1. 修改定時器分頻系數(推薦) STC8H的定時器支持獨立分頻,無需降低主頻即可解決時序問題。假設原51使用12MHz晶振,定時器配置為12分頻,移植到STC8H時需調整如下: c // 定時器初始化示例(Timer0) void Timer0_Init(void) { AUXR |= 0x80; // 定時器0設置為1T模式 TMOD &= 0xF0; // 清除定時器0模式位 TMOD |= 0x01; // 定時器0設為模式1(16位自動重載) TL0 = 0x00; // 初始化計時值 TH0 = 0x00; ET0 = 1; // 使能定時器0中斷 TR0 = 1; // 啟動定時器0 // 關鍵設置:定時器時鐘分頻(假設原51為12分頻) T0H = (65536 - (FOSC / 12 / 1000)) >> 8; // 舉例:1ms中斷 T0L = (65536 - (FOSC / 12 / 1000)) & 0xFF; } 2. 調整系統時鐘分頻 若解碼邏輯依賴全局延時(如nop循環),可降低系統時鐘至原51的1/12: c // 在程序初始化時設置時鐘分頻 CLKDIV = 0x0B; // 系統時鐘12分頻(主頻=外部晶振/12) 3. 修改軟件延時函數 若代碼中有基于循環的軟件延時,需將延時倍數調整為12倍: c void Delay1ms() { unsigned int i, j; for (i=0; i<12; i++) { // 原循環次數乘以12 for (j=0; j<1000; j++); } } 4. 檢查外部中斷配置 315MHz解碼通常依賴外部中斷檢測信號邊沿。確保STC8H的IO口模式配置正確(建議設置為高阻輸入): c P1M1 |= 0x01; // P1.0設為高阻輸入 P1M0 &= ~0x01; IT0 = 1; // 設置INT0為下降沿觸發 EX0 = 1; // 使能INT0中斷 EA = 1; // 全局中斷使能 |