|
單片機的引腳,可以用程序來控制,輸出高、低電平,這些可算是單片機的輸出電壓。 單片機輸出低電平時,將允許外部器件,向單片機引腳內(nèi)灌入電流,這個電流,稱為“灌電流”,外部電路稱為“灌電流負載”; 這些電流一般是多少?最大限度是多少? 這就是常見的單片機輸出驅(qū)動能力的問題。 早期的 51 系列單片機的帶負載能力,是很小的,僅僅用“能帶動多少個 TTL 輸入端”來說明的。 分析一下 TTL 的輸入特性,就可以發(fā)現(xiàn),51 單片機基本上就沒有什么驅(qū)動能力。 記得是在 AT89C51 單片機流行起來之后,做而論道才發(fā)現(xiàn):單片機引腳的能力大為增強,可以直接帶動 LED 發(fā)光了。
雖然引腳已經(jīng)可以直接驅(qū)動 LED 發(fā)光,但是且慢,先別太高興,還是看看 AT89C51 單片機引腳的輸出能力吧。 Maximum IOL per port pin: 10 mA; 這里是說: 而當這些引腳“輸出高電平”的時候,單片機的“拉電流”能力呢? 可以說是太差了,竟然不到 1 mA。 結(jié)論就是:單片機輸出低電平的時候,驅(qū)動能力尚可,而輸出高電平的時候,就沒有輸出電流的能力。 51 單片機的這些特性,是源于引腳的內(nèi)部結(jié)構(gòu),引腳內(nèi)部結(jié)構(gòu)圖這里就不畫了,很多書中都有。 再看看上面的電路圖: 哦,明白了,外接電路如果是“拉電流負載”,要求單片機輸出高電平時發(fā)揮作用,那就必須用“上拉電阻”來協(xié)助,產(chǎn)生負載所需的電流。 下面做而論道就專門說說上拉電阻存在的問題。 從上面的圖中可以看到,D2 發(fā)光,是由上拉電阻 R2 提供的電流,D2 導通發(fā)光的電壓約為 2V,那么發(fā)光的電流就是:(5 - 2) / 1K,約為 3mA。 而當單片機輸出低電平(0V),D2 不發(fā)光的時候,R2 這個上拉電阻閑著了嗎? 沒有!它兩端的電壓,比 LED 發(fā)光的時候還高,現(xiàn)在是 5V 了,其中的電流,是 5mA ! 如果在一個 8 位的接口,安裝了 8 個 1K 的上拉電阻,當單片機都輸出低電平的時候,就有 40mA 的電流灌入這個 8 位的接口! 那么,把上拉電阻加大些,可以嗎? 對于 D1,是灌電流負載,單片機輸出低電平的時候,R1、D1 通路上會有灌電流;輸出高電平的時候,那就什么電流都沒有,此時就不產(chǎn)生額外的耗電。 綜上所述,灌電流負載,是合理的;而“拉電流負載”和“上拉電阻”會產(chǎn)生很大的無效電流,這種電路不合理。 有些網(wǎng)友對上拉電阻情有獨鐘,有用沒用的,都想在引腳上安裝個上拉電阻,甚至還能說出些理由:穩(wěn)定性啦、速度啦...。 做而論道看過很多關(guān)于單片機引腳以及上拉電阻方面的書籍、參考資料,基本上它們對于使用上拉電阻的弊病都沒有進行仔細的討論。 在此,做而論道鄭重向大家提出建議:設(shè)計單片機的負載電路,應該采用“灌電流負載”的電路形式,以避免無謂的電流消耗。 上拉電阻,僅僅是在 P0 口才考慮加不加的問題:當用 P0 口做為輸入口的時候,需要加上、當用 P0 口輸出高電平驅(qū)動 MOS 型負載的時候,也需要加上,其它的時候,P0 口也不用加入上拉電阻。 在其它接口(P1、P2 和 P3),都不應該加上拉電阻,特別是輸出低電平有效的時候,外接器件就有上拉的作用。 |
|
|
來自: 欲悠游天下 > 《Technology》