日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 單片機 > 單片機
[導讀]現(xiàn)在的存儲器已經(jīng)不像七八年前那樣昂貴了,但是ram相對于rom和eeprom的價格還是不可同樣看待的,所以程序中節(jié)省內(nèi)存在現(xiàn)在看來還是非常關鍵的。原因有以下幾點:1.ram的存取速度相對于eeprom的存取速度要快很多倍,不

現(xiàn)在的存儲器已經(jīng)不像七八年前那樣昂貴了,但是ram相對于rom和eeprom的價格還是不可同樣看待的,所以程序中節(jié)省內(nèi)存在現(xiàn)在看來還是非常關鍵的。原因有以下幾點:

1.ram的存取速度相對于eeprom的存取速度要快很多倍,不在一個數(shù)量級上,主要是因為eeprom的存儲要想寫入就必須先擦除,而且eeprom的擦出需要成塊擦除(這是由于eeprom的擦除原理是場效應管的柵極上電擦除的,為了節(jié)省成本廠家一般都是8Bytes/page 64Bytes/page),所以使用ram來處理中間的數(shù)據(jù)是能夠符合速度要求的。

2.無論是xram還是eeprom都是外部存儲器,在負值時都要用到16bit地址空間(8位機),這樣無形中就增大了程序的code的體積并且使得速度上也受到影響,所以盡量把indata區(qū)的ram用到極限是非常有意義的。

本人總結了一些節(jié)省內(nèi)存的規(guī)律,提供給大家討論一下,看看是否可行。

1.內(nèi)存分配的基本原理:

keil與其他的c語言編譯器我認為從內(nèi)存分配的原理上是基本相同的。總結起來,其實很簡單,就是選最長的路徑進行編譯(話糙理不糙),例如下面的兩段程序

program 1:

unsigned char a();

void b();

void main()

{

unsigned char byte1;

unsigned char byte2;

byte1 = byte2 = 3;

if( a() == 3)

{

b();

}

a();

return;

}

// a function

unsigned char a()

{

unsigned char byte_a1;

unsigned char byte_a2;

byte_a1 = byte_a2 = 3;

byte_a1 = 4;

byte_a2 = 5;

return byte_a1;

}

// b function

void b()

{

unsigned char byte_b1;

unsigned char byte_b2;

unsigned char byte_b3;

byte_b1 = byte_b2 = byte_b3 = 3;

return;

}

program 2:

void a();

void b();

void main()

{

unsigned char byte1;

unsigned char byte2;

byte1 = byte2 = 3;

a();

return;

}

// a function

void a()

{

unsigned char byte_a1;

unsigned char byte_a2;

byte_a1 = byte_a2 = 3;

if (byte_a1 == 3)

{

b();

}

byte_a1 = 4;

byte_a2 = 5;

return;

}

// b function

void b()

{

unsigned char byte_b1;

unsigned char byte_b2;

unsigned char byte_b3;

byte_b1 = byte_b2 = byte_b3 = 3;

return;

}

兩段程序的作用是相同的,都是先執(zhí)行函數(shù)a,然后根據(jù)byte_a1的值判斷去執(zhí)行b程序,但是用keil編譯的結果卻不相同program 1 編譯的結果是data:14 code:48,而program 2 編譯的結果是data:16 code:56,可見program 1 比 program 2 即節(jié)省了code又節(jié)省了內(nèi)存。

看一下反匯編代碼,就可以了解原因了,在a函數(shù)中調(diào)用b函數(shù),a函數(shù)定義的byte_a1和byte_a2變量沒有被釋放,所以program 2 的內(nèi)存分配是 8(SFR) + 1(STACK) + 2(MAIN FUNC) + 2(A FUNC) + 3(B FUNC) = 16 Bytes,而program 1 的內(nèi)存分配是 8(SFR) + 1(STACK) + 3(B FUNC) = 14Bytes, 由于B函數(shù)和A函數(shù)是并行的,所以節(jié)省了a函數(shù)需要的2個字節(jié)。

這樣總結看來程序不要串行,應盡量并行,充分利用有限的ram資源,這樣既可以使code區(qū)變小,也可以使速度變快。

2.uncalled segment 影響內(nèi)存分配:

不知道大家是否發(fā)現(xiàn)過當存在沒有調(diào)用的函數(shù)時,內(nèi)存空間很有可能會溢出,這個原因其實也非常簡單例如:

program 3:

void a();

void b();

void c(unsigned char byte_input);

void main()

{

unsigned char byte1;

unsigned char byte2;

byte1 = byte2 = 3;

a();

c(3);

return;

}

// a function

void a()

{

unsigned char byte_a1;

unsigned char byte_a2;

byte_a1 = byte_a2 = 3;

if (byte_a1 == 3)

{

b();

}

byte_a1 = 4;

byte_a2 = 5;

return;

}

// b function

void b()

{

unsigned char byte_b1;

unsigned char byte_b2;

unsigned char byte_b3;

byte_b1 = byte_b2 = byte_b3 = 3;

return;

}

void c(unsigned char byte_input)

{

unsigned char byte_c;

byte_c = byte_input;

return;

}

program 3 所示如果再main.c里面調(diào)用c(3)編譯后data:16,而如果不調(diào)用c(3),編譯后data:17,原因是調(diào)用c(3) data = 8(SFR) + 1(STACK) + 2(MAIN FUNC) + 2(A FUNC) + 3(B FUNC) = 16Bytes,而如果不調(diào)用c(3) data = 8(SFR) + 1(STACK) + 2(MAIN FUNC) + 2(A FUNC) + 3(B FUNC) + 1(C FUNC) = 17 Bytes。

所以,建議大家如果暫時不調(diào)用的函數(shù)最好屏蔽掉,以免影響整體的內(nèi)存分配。


本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關閉