1581, 70/80 ȸ¿ø°¡ÀÔ  ·Î±×ÀΠ 
   wolverine
   [ÀÚÀÛ] C °­ÁÂ [4] - Dynamic Memory Allocation

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 : 5932     Date : 2012/07/06 11:24



    
pkw5240 ¤¾¤¾´ÙÀ½±ÛÀº ¹º°¡¿©? ¾ó¸¥¿Ã·ÁÁÖ¼¼¿ä 2012/07/11  
wolverine °ð ¿Ã¶ó°©´Ï´Ù. ȸ»ç¿¡¼­ Á¡½É½Ã°£¿¡ ««È÷ ¾²°í Àִµ¥ .... ¤¾¤¾ 2012/07/11  
201   [ÀÚÀÛ]M's HTML lecture[3]     Myers
03/21 5942
200   cÀÇ Æ¯Â¡     smartbloger
06/16 5941
199   [ÀÚÀÛ] sbcl tcp Ŭ¶óÀ̾ðÆ® ¿¹Á¦     ruka270
12/27 5940
198     [re] ÇØÄ¿¶õ?     dpttm2
03/12 5935
  [ÀÚÀÛ] C °­ÁÂ [4] - Dynamic Memory Allocation[2]     wolverine
07/06 5931
196   C ¾ð¤· ¤Ã goto(x,y)[4]     hackerÅ×µð
12/31 5919
195   ½ºÅ©¸³Æ®¾Ë·ÁÁֽǺÐ~1     lcd7132
05/03 5917
194   ´ÔÀÌ ¿©±â ´Ù µµ¹èÇÞ¾î¿ä..[1]     rabbitlycat
05/08 5917
193   [ÀÚÀÛ]GoogleÇØÅ·±âº»-ÀÍ¸í¼ºÀ» À§ÇÑ Ä³½Ã»ç¿ëPart2[5]     lsn10919
10/11 5897
192   [ÀÚÀÛ]IPÁÖ¼Ò¿¡ ´ëÇØ     kn0p
02/27 5846
191   ½ºÅ©¸³Æ® À߸¸µå½Ã´ÂºÐ~     lcd7132
04/26 5844
190   Visual Basic 6.0v[2]     sibu02003
05/10 5842
189   ³×Æ®¿öÅ© LAN°ú WAN [3]     lcyoung98
07/23 5839
188   [ÀÚÀÛ] Stack based Buffer Overflow[2]     HEx0D
02/12 5831
187   ½ºÅ©¸³Æ®¾Ë·ÁÁֽǺÐ~2     lcd7132
05/03 5831
186   [ÀÚÀÛ] Ãʺ¸ ¸®¹ö½Ì ! [5][2]     siosio24
08/17 5830
185   [ÀÚÀÛ±Û]¸®´ª½º¿¡¼­ c¾ð¾î¸¦ ÄÄÆÄÀÏÇغ¸ÀÚ!     ÇѽÂÀç
01/06 5826
184   [ÀÚÀÛ] HTML 6,7,8     Myers
08/11 5818
183   [ÀÚÀÛ] HTML Lecture 5[2]     Myers
05/16 5816
182   ½ºÅ©¸³Æ® ¾Ë·ÁÁֽǺÐ~     lcd7132
04/29 5816
[1]..[61][62][63][64][65][66][67][68][69] 70 ..[80]

Copyright 1999-2024 Zeroboard / skin by Hackerschool.org / Secure Patch by Hackerschool.org