<address id="tnvjh"></address>
    <form id="tnvjh"><listing id="tnvjh"><meter id="tnvjh"></meter></listing></form>

      <form id="tnvjh"></form>

      <address id="tnvjh"><th id="tnvjh"></th></address>

        專注電子技術學習與研究
        當前位置:單片機教程網 >> MCU設計實例 >> 瀏覽文章

        單片機編程中C語言和匯編的差異

        作者:佚名   來源:本站原創   點擊數:  更新時間:2009年10月01日   【字體:

         最近對比了下C語言和匯編兩種語言在單片機領域的差異。匯編作為低級語言,是僅次于機器語言和硬件聯系最緊密的語言;而C語言,嚴格的說也只能算是半個高級語言,相對于其他高級語言來說。這兩者比較直觀的差異是:匯編語言的實時性非常好,但可讀性差,可移植性不強;相反,C語言的可讀性強,可移植性高,但實時性比較差。
          利用C語言編寫單片機程序,不用考慮程序的初始化地址,不用考慮ACC,PSW以及工作寄存器的保護,不用考慮溢出進位CY。而匯編這些都需要考慮到。
          今天在編寫溫度計程序的時候遇到了這個問題,因為以前是用匯編寫的,現在翻譯成C,在處理負數轉換的時候遇到了問題。因為如果溫度計轉換芯片讀出來的是負數,他是以反碼的形式表示的,需要對其取反加一。這樣就不得不考慮加一后可能溢出的情況。在匯編里這種情況處理起來很簡單,低位字節的加法用ADD指令,高位字節用ADDC,這樣,如果低位有溢出,CY會置一,高字節ADDC在計算時會將進位CY計算在內。但在C里面就不是這回事了。低字節有溢出,不會影響高字節的加法,這樣計算的結果是錯誤的。請教了下高手,解決方法可以嵌入匯編,也可以直接使用ACC和CY,即每次高位的加法前要先判斷CY的值,為1則多加1,為0則正常加法。因為在引用的reg51.h的頭文件里包含了這些寄存器和標志位的定義。
            這里有一個典型的例子:http://www.lauradisbro.com/mcu/710.html  大家可以從中悟出匯編和c的區別在實際應用中好好把握就行了
              當然c語言的簡單與方便這是匯編不能比的,我個人覺得把單片機c語言和匯編語言結合來編成是最好的。在需要很精確的地方就嵌套一個匯編的子程序,其他就用c語言。
          這些只是本人在平時的實踐中作出的小小總結,還請高手給出意見。如有不對,還請批評指出。共同切磋共同進步!

        關閉窗口

        相關文章

        和老头做爰很舒服,JK白丝裤袜开裆自慰喷水,在线天堂www在线...中文

          <address id="tnvjh"></address>
          <form id="tnvjh"><listing id="tnvjh"><meter id="tnvjh"></meter></listing></form>

            <form id="tnvjh"></form>

            <address id="tnvjh"><th id="tnvjh"></th></address>