http://www.hackerschool.org/HS_Boards/zboard.php?id=Free_Lectures&no=2036 [º¹»ç]
À̹ø Àå¿¡¼´Â dynamic memory allocation ¿¡ ´ëÇؼ ¾Ë¾Æº¸°Ú½À´Ï´Ù.
Áö±Ý±îÁö °ÀǸ¦ ÅëÇؼ
global variable˼
build time memory allocation,
Áï, build¸¦ ÇÒ ¶§¿¡ º¯¼ö°¡ ÇÒ´çµÇ´Â memory address°¡ °áÁ¤À̵Ǹç,
º¯¼öÀÇ life-timeÀº ÇÁ·Î±×·¥ÀÌ ³¡³¯¶§±îÁö,
Áï, ÇÁ·Î±×·¥ÀÌ Á¾·á µÉ¶§±îÁö ¸Þ¸ð¸®ÀÇ °ø°£À» Â÷ÁöÇÏ°í ÀÖ´Ù
¶ó´Â °ÍÀ» ¹è¿ü½À´Ï´Ù.
¶ÇÇÑ local variableÀº
stack À̶ó´Â ¸Þ¸ð¸® ¿µ¿ª¿¡ ÇöÀç stack pointerÀÇ À§Ä¡¿¡ µû¶ó¼ ±×¶§ ±×¶§ ÇÒ´çÀÌ µÇ¸ç,
º¯¼öÀÇ life-timeÀº ÇØ´ç ÇÔ¼ö°¡ return µÉ¶§±îÁö,
Áï, ÇÔ¼ö°¡ returnÀÌ µÇ¸é, º¯¼öÀÇ »ý¸íµµ ³¡ÀÌ ³ª¸ç,
stack pointerµµ ÇÔ¼ö°¡ È£ÃâµÇ±â ÀÌÀüÀÇ À§Ä¡·Î º¹±ÍÇϸç,
¶Ç ´Ù¸¥ ÇÔ¼ö¿¡¼ ¶Ç ´Ù¸¥ local º¯¼ö°¡ µ¿ÀÏÇÑ stack¿¡ ÇÒ´çÀÌ µÉ ¼ö ÀÖ´Ù
¶ó´Â °ÍÀ» ¹è¿ü½À´Ï´Ù.
global variable˼
¼·Î ´Ù¸¥ ¿©·¯ ÇÔ¼ö¿¡¼ Á¢±Ù(access, read/write) °¡´ÉÇϸç,
Å©±â°¡ Å« array ÇüÅ·Π¼±¾ðÇÒ ¼ö ÀÖÁö¸¸,
local variable˼
ÇÔ¼ö ³»¿¡¼¸¸ Á¢±Ù °¡´ÉÇϸç,
Å©±â°¡ Å« array ·Î ¼±¾ðÇϱ⿡´Â stack overflowÀÇ À§ÇèÀÌ ÀÖ½À´Ï´Ù.
±×·³, ´ÙÀ½°ú °°Àº func1~func9±îÁö ¼øÂ÷ÀûÀ¸·Î
È£ÃâµÇ´Â ÇÁ·Î±×·¥ÀÌ ÀÖ´Ù°í °¡Á¤À» Çغ¸ÁÒ.
func1();
func2();
func3();
func4();
func5();
func6();
func7();
func8();
func9();
À̶§¿¡,
func1~3´Â µ¿ÀÏÇÑ int a[10000]À̶ó´Â º¯¼ö ¹è¿À» access ÇÏ°í,
func4~6´Â µ¿ÀÏÇÑ int b[10000]À̶ó´Â º¯¼ö ¹è¿À» access ÇÏ°í,
func7~9´Â µ¿ÀÏÇÑ int c[10000]À̶ó´Â º¯¼ö ¹è¿À» access ÇÑ´Ù°í,
°¡Á¤À» Çغ¾½Ã´Ù.
°¡Àå °£´ÜÇÏ°Ô´Â global variable·Î a,b,c ¸ðµÎ¸¦ ¼±¾ðÇÏ¸é µË´Ï´Ù.
ÇÏÁö¸¸, Àüü ÇÁ·Î±×·¥ÀÇ life-time µ¿¾È a,b,c°¡ Ç×»ó ¸Þ¸ð¸® °ø°£À» Â÷ÁöÇÏ°Ô µË´Ï´Ù.
func1~3ÀÌ ¼öÇàµÇ´Â µ¿¾ÈÀº b,c´Â ÀüÇô ÇÊ¿ä°¡ ¾ø´Âµ¥µµ ¸»ÀÌÁÒ...
ÀÌ·¯ÇÑ »óȲ¿¡¼ ¸Þ¸ð¸®¸¦ È¿À²ÀûÀ¸·Î ¿î¿ëÇϱâ À§Çؼ
dynamic memory allocation À» »ç¿ëÇÏ°Ô µË´Ï´Ù.
ÇÁ·Î±×·¥Àº ´ÙÀ½°ú °°ÀÌ ±×¶§ ±×¶§ ÇÊ¿äÇÑ º¯¼ö ¹è¿¿¡ ´ëÇÑ ¸Þ¸ð¸® ¿µ¿ªÀ» ÇÒ´ç ¹Þ¾Æ¼
»ç¿ëÇÏ°í, »ç¿ëÀÌ ³¡³ª¸é ÇÒ´ç ¹ÞÀº ¸Þ¸ð¸® ¿µ¿ªÀ» ´Ù½Ã ÇØÁ¦ ÇÏ°Ô µË´Ï´Ù.
µ¿Àû ¸Þ¸ð¸® ÇÒ´ç
func1(); // ¸Þ¸ð¸® ÀÌ¿ë
func2(); // ¸Þ¸ð¸® ÀÌ¿ë
func3(); // ¸Þ¸ð¸® ÀÌ¿ë
¸Þ¸ð¸® ÇØÁ¦
µ¿Àû ¸Þ¸ð¸® ÇÒ´ç
func4(); // ¸Þ¸ð¸® ÀÌ¿ë
func5(); // ¸Þ¸ð¸® ÀÌ¿ë
func6(); // ¸Þ¸ð¸® ÀÌ¿ë
¸Þ¸ð¸® ÇØÁ¦
µ¿Àû ¸Þ¸ð¸® ÇÒ´ç
func7(); // ¸Þ¸ð¸® ÀÌ¿ë
func8(); // ¸Þ¸ð¸® ÀÌ¿ë
func9(); // ¸Þ¸ð¸® ÀÌ¿ë
¸Þ¸ð¸® ÇØÁ¦
µ¿Àû ¸Þ¸ð¸®´Â heap¿µ¿ª¿¡ ÇÒ´çÀÌ µÇ¸ç,
heapÀÇ Å©±â¸¸Å µ¿Àû ¸Þ¸ð¸®¸¦ ÇÒ´çÀÌ °¡´ÉÇÕ´Ï´Ù.
int *a;
a = (int*)malloc(10000*4); // 10000x4 byte µ¿Àû ¸Þ¸ð¸® ÇÒ´ç
a[n] ÇüÅÂÀÇ ¹è¿·Î ÀÌ¿ë...
free(a); // ÇÒ´çµÈ ¸Þ¸ð¸®¸¦ ÇØÁ¦.
freeÇÔ¼ö´Â ÇÒ´çµÈ ¸Þ¸ð¸®¸¦ ÇØÁ¦½ÃÄÑ ÁÝ´Ï´Ù.
ÇØÁ¦¶ó´Â ¸»Àº ÇöÀç a°¡ Àâ°íÀÖ´Â ¹°¸®ÀûÀÎ ¸Þ¸ð¸® °ø°£À»
´Ù¸¥ malloc¿¡ ÀÇÇؼ ÀÌ¿ë°¡´ÉÇϵµ·Ï ÇÏ´Â °ÍÀÔ´Ï´Ù.
¸¸¾à ´ÙÀ½°ú °°ÀÌ a,b¸¦ Â÷·Ê·Î ÇÒ´çÇϸé,
a = (int*)malloc(10000*4);
b = (int*)malloc(10000*4);
b´Â aÀÇ base address¿¡¼ 40000 byte ¶³¾îÁø °ø°£¿¡ ÇÒ´çÀÌ µË´Ï´Ù.
ÇÏÁö¸¸, ´ÙÀ½°ú °°ÀÌ free°¡ µé¾î°¡¸é,
a = (int*)malloc(10000*4);
free(a);
b = (int*)malloc(10000*4);
b´Â a°¡ ÇÒ´çµÇ¾ú´ø ¸Þ¸ð¸® À§Ä¡¿¡ ´Ù½Ã ÇÒ´çµÇ°Ô µË´Ï´Ù.
ÀÌ·± °³³äÀ¸·Î dynamic memory allocationÀº
Á¦ÇÑµÈ ¸Þ¸ð¸® ȯ°æ¿¡¼ È¿À²ÀûÀÎ ¸Þ¸ð¸® È°¿ëÀ» À§Çؼ
¹Ýµå½Ã ÇÊ¿äÇÑ µµ±¸ ÀÔ´Ï´Ù.
½ÇÁ¦ »ó¿ë ÇÁ·Î±×·¥¿¡¼ ÇʼöÀûÀ¸·Î ÀÌ¿ëµÇ´Â Áß¿äÇÑ °³³äÀÔ´Ï´Ù.
ÀÌ»óÀ¸·Î À̹ø ÀåÀ» ¸¶Ä¡°Ú½À´Ï´Ù.
Best Regards,
Wolverine
|
Hit : 6447 Date : 2012/07/06 11:24
|