1581, 10/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 : 5915     Date : 2012/07/06 11:24



    
pkw5240 ¤¾¤¾´ÙÀ½±ÛÀº ¹º°¡¿©? ¾ó¸¥¿Ã·ÁÁÖ¼¼¿ä 2012/07/11  
wolverine °ð ¿Ã¶ó°©´Ï´Ù. ȸ»ç¿¡¼­ Á¡½É½Ã°£¿¡ ««È÷ ¾²°í Àִµ¥ .... ¤¾¤¾ 2012/07/11  
1401     [re] °¡Â¥¹é½Å (2)     izi1008
12/24 5786
1400   [Æß] C ÇÁ·Î±×·¥ÀÇ ÀϹÝÀûÀÎ ±¸Á¶ [ù°­ÁÂ][3]     Cpgroot
08/19 5791
1399   [ÀÚÀÛ] HTML Lecture 5[2]     Myers
05/16 5795
1398   [ÀÚÀÛ] HTML 6,7,8     Myers
08/11 5795
1397   [ÀÚÀÛ±Û]¸®´ª½º¿¡¼­ c¾ð¾î¸¦ ÄÄÆÄÀÏÇغ¸ÀÚ!     ÇѽÂÀç
01/06 5795
1396   ½ºÅ©¸³Æ®¾Ë·ÁÁֽǺÐ~2     lcd7132
05/03 5811
1395   [ÀÚÀÛ] Ãʺ¸ ¸®¹ö½Ì ! [5][2]     siosio24
08/17 5813
1394   [ÀÚÀÛ] Stack based Buffer Overflow[2]     HEx0D
02/12 5814
1393   ³×Æ®¿öÅ© LAN°ú WAN [3]     lcyoung98
07/23 5820
1392   ½ºÅ©¸³Æ® À߸¸µå½Ã´ÂºÐ~     lcd7132
04/26 5821
1391   Visual Basic 6.0v[2]     sibu02003
05/10 5825
1390   [ÀÚÀÛ]IPÁÖ¼Ò¿¡ ´ëÇØ     kn0p
02/27 5828
1389   [ÀÚÀÛ]GoogleÇØÅ·±âº»-ÀÍ¸í¼ºÀ» À§ÇÑ Ä³½Ã»ç¿ëPart2[5]     lsn10919
10/11 5879
1388   ½ºÅ©¸³Æ®¾Ë·ÁÁֽǺÐ~1     lcd7132
05/03 5890
1387   ´ÔÀÌ ¿©±â ´Ù µµ¹èÇÞ¾î¿ä..[1]     rabbitlycat
05/08 5894
1386   C ¾ð¤· ¤Ã goto(x,y)[4]     hackerÅ×µð
12/31 5902
  [ÀÚÀÛ] C °­ÁÂ [4] - Dynamic Memory Allocation[2]     wolverine
07/06 5914
1384   [ÀÚÀÛ] sbcl tcp Ŭ¶óÀ̾ðÆ® ¿¹Á¦     ruka270
12/27 5917
1383     [re] ÇØÄ¿¶õ?     dpttm2
03/12 5918
1382   ¸®´ª½º Áú¹®ÀÌ¿ä[6]     ppl8271
03/11 5920
[1][2][3][4][5][6][7][8][9] 10 ..[80]

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