Ⅰ lx51與BL51,AX51與A51,CX51與C51分別有什麼區別
詳見A51手冊的附錄D:匯編器的差異<br /><br />A51與BL51:<br />針對傳統8051單片機的開發工具,最大支持32×64KB Code Bank。<br /><br />AX51與LX51:<br />針對傳統8051單片機以及部分衍生型號的開發工具,最大支持外擴16 MB的xdata或code。AX51匯編器是A51匯編器的超集,兩者的主要差異包括:<br />1.AX51中的數值默認為32位,A51是16位;<br />2.AX51不包含8051的默認SFR定義;<br />3.AX51支持更多的特殊符號,例如ECALL等;<br />4.生成的目標文件不同。AX51生成的目標文件為OMF-251/51MX格式,不受傳統OMF-51格式中每個模塊不得超過256個外部符號及段的限制。
Ⅱ c語言有幾種分配內存的方式,有什麼區別
內存分配方式有三種:
[1]從靜態存儲區域分配。內存在程序編譯的時候就已經分配好,這塊內存在程序的整個運行期間都存在。例如全局變數,static變數。
[2]在棧上創建。在執行函數時,函數內局部變數的存儲單元都可以在棧上創建,函數執行結束時這些存儲單元自動被釋放。棧內存分配運算內置於處理器的指令集中,效率很高,但是分配的內存容量有限。
[3]從堆上分配,亦稱動態內存分配。程序在運行的時候用malloc或new申請任意多少的內存,程序員自己負責在何時用free或delete釋放內存。動態內存的生存期由程序員決定,使用非常靈活,但如果在堆上分配了空間,就有責任回收它,否則運行的程序會出現內存泄漏,頻繁地分配和釋放不同大小的堆空間將會產生堆內碎塊。
Ⅲ 為什麼會有大小端模式之分呢
這是因為在計算機系統中,我們是以位元組為單位的,每個地址單元都對應著一個位元組,一個位元組為8bit。但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對於位數大於8位的處理器,例如16位或者32位的處理器,由於寄存器寬度大於一個位元組,那麼必然存在著一個 如何將多個位元組安排 的問題。因此就導致了 大端存儲模式 和 小端存儲模式 。
例如一個16bit的short型x,在內存中的地址為0x0010,x的值為0x1122,那麼0x11為高位元組,0x22為低位元組。對於大端模式,就將0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,剛好相反。我們常用的X86結構是小端模式,而KEIL C51則為大端模式。很多的ARM,DSP都為小端模式。有些ARM處理器還可以由硬體來選擇是大端模式還是小端模式。
• Little-Endian:低位位元組排放在內存的低地址端,高位位元組排放在內存的高地址端。示例數字0x12 34 56 78在內存中的表示形式:
內存 低地址 -----------------> 高地址
0x78 | 0x56 | 0x34 | 0x12 *
低位子節 -----------------> 高位子節*
• Big-Endian:高位位元組排放在內存的低地址端,低位位元組排放在內存的高地址端。示例數字0x12 34 56 78在內存中的表示形式:
內存 低地址 -----------------> 高地址
0x12 | 0x34 | 0x56 | 0x78
高位子節 -----------------> 低位子節
可見,大端模式和字元串的存儲模式類似。但是也有各自的特點:
• 小端模式 :強制轉換數據不需要調整位元組內容,1、2、4位元組的存儲方式一樣。
• 大端模式 :符號位的判定固定為第一個位元組,容易判斷正負。
則可以通過以下方式判斷機器的子節序
或者 利用聯合體union成員的存放順序都是從低地址開始的特性來做判斷。
為了方便討論,假設m_RegMW[0] = 0x3456; 在內存中為0x56、0x34。
現要將該數據發出,如果不進行數據轉換直接發送,此時發送的數據為0x56,0x34。而Modbus是大端的,會將該數據解釋為0x5634而非原數據0x3456,此時就會發生災難性的錯誤。所以,在此之前,需要將小端數據轉換成大端的,即進行高位元組和低位元組的交換,此時可以調用步驟五中的函數BigtoLittle16(m_RegMW[0]),之後再進行發送才可以得到正確的數據。