keilc51中如何看堆棧的分配情況
但,今天發生的事情證明我錯了。
本文引用地址:http://www.104case.com/article/201611/323457.htm手頭上有個產品的代碼,代碼量很大。程序跑起來的效果不大好,因此打算把代碼優化一下。代碼量越大,通常可優化的地方也越多。對8051來說,訪問芯片內部的data區(0~7FH)內存速度是最快的,直接訪問,一條指令就能讀寫,而idata區(80H~FFH)雖然還是內存區,但由于地址分配上跟特殊寄存器SFR重合,只能間接地址訪問,兩條指令才能讀寫,速度稍慢點,而外存xdata區(0~7FFFH)必須使用DPTR指針才能訪問,速度是最慢的。很明顯,優化的原則就是盡量把頻繁讀寫的變量優先安排在data區,然后是idata區,最后才是xdata區。
8051在物理上有4個存儲器空間
片內ROM和片外ROM。片內RAM和片外RAM。
片外程序存儲器ROM地址空間為64kB,片外數據存儲器RAM也有64kB的尋址區,在地址上是與ROM重迭的。
8051單片機通過不同信號來選通ROM或RAM。當從外部ROM中取指令時,采用選通信號PSEN,而從外部RAM中讀寫數據時
則采用讀RD和寫WR信號或來選通,因此不會因地址重迭而發生混亂。
評論