|
這是我們的實驗,用89C51單片機定時器中斷的方法實現定時器T0,工作方式1實現LED燈1s節拍閃爍,附帶有單片機代碼文件和protuse仿真工程文件。
這段代碼的功能是利用8051單片機的定時器0(Timer 0)來控制P2端口的閃爍。程序的核心邏輯是通過定時器溢出(`TF0`)來計數,當計數達到20次時,翻轉P2端口的電平狀態,并重置計數器。以下是代碼的詳細分析和解釋:
代碼功能
• 硬件接口:
• 使用P2端口來輸出信號,初始狀態為全高電平(`0xFF`)。
• 使用定時器0(Timer 0)來產生定時溢出。
• 主要功能:
• 定時器0設置為模式1(16位定時器模式)。
• 定時器溢出時間初始為50ms(50000機器周期),之后改為30ms(30000機器周期)。
• 每次定時器溢出時,計數器`N`加1。
• 當`N`達到20時,翻轉P2端口的電平狀態,并重置`N`為0。
代碼結構
主函數(`main`)
- void main()
- {
- TMOD = 0x01; // 設置定時器0為模式1(16位定時器模式)
- TH0 = (65535 - 50000) / 256; // 設置定時器高8位初值,初始定時50ms
- TL0 = (65535 - 50000) % 256; // 設置定時器低8位初值
- TR0 = 1; // 啟動定時器0
- TF0 = 0; // 清除定時器0溢出標志
- P2 = 0xFF; // 初始化P2端口為全高電平
- while (1)
- {
- while (TF0 == 0); // 等待定時器0溢出
- TF0 = 0; // 清除定時器0溢出標志
- N++; // 計數器加1
- if (N == 20) // 判斷計數器是否達到20
- {
- P2 = ~P2; // 翻轉P2端口的電平狀態
- N = 0; // 重置計數器
- }
- TH0 = (65535 - 30000) / 256; // 重新設置定時器高8位初值,改為30ms
- TL0 = (65535 - 30000) % 256; // 重新設置定時器低8位初值
- }
- }
復制代碼
代碼邏輯分析
• 定時器初始化:
• `TMOD = 0x01;`:設置定時器0為模式1(16位定時器模式)。
• `TH0`和`TL0`:設置定時器初值,使定時器溢出時間為50ms(機器周期為12MHz)。
• `TR0 = 1;`:啟動定時器0。
• `TF0 = 0;`:清除定時器0的溢出標志。
• 主循環:
• `while (TF0 == 0);`:等待定時器0溢出。
• `TF0 = 0;`:清除定時器0的溢出標志,防止中斷觸發。
• `N++;`:計數器加1。
• `if (N == 20)`:當計數器達到20時,翻轉P2端口的電平狀態,并重置計數器。
• 之后將定時器溢出時間改為50ms。
• P2端口翻轉:
• `P2 = ~P2;`:翻轉P2端口的電平狀態,實現閃爍效果。
當中的問題不會可以發在評論區,如果收到我會回復的。謝謝大家!希望和一起學習進步。
|
評分
-
查看全部評分
|