malloc 관련 코딩에 대한 설명 부탁드립니다.
바람
질문 제목 : malloc 관련 코딩에 대한 설명
코딩을 보면서 이해가 되지 않는 부분이 있는데 보조적인 설명 부탁드립니다.질문 내용 :
안녕하세요
윤성우의 c 프로그래밍을 보면은 페이지 591~592(해답지 부분)에
이렇게 코딩이 되어있는데 코딩을 보면서 이해가 안되는 부분이 있기에
빨간색으로 이해하기 어려운 부분을 체크하고
그 부분에 대한 설명 부탁드립니다.
#includestdio.h
#includestdlib.h
#pragma warning(disable:4996)
void extendsize(int** parr, int* psz);
int main()
{
int arrsize=5;// 초기 배열 크기
int index=0;// 배열 인덱스
int i;
int *arr=(int*)malloc(sizeof(int)*arrsize);
while(1)
{
printf(number ? : );
scanf(%d,&arr[index]);
- &arr[index]를 쓰는 이유가 무엇인가요? index값은 0인 것도 알고 arr도 5바이트를 할당 받은것도 알겠는데...
왜 이렇게 쓰이고 배열로 선언을 하게 된것인지 궁금합니다.
if(arr[index] == -1)// 입력의 종료 검사
{
break;
}
if(arrsize == index+1)// 배열 확장 검사
{
extendsize(&arr,&arrsize);
- extendsize 함수에 이2개의 값을 전달하는것에 대한설명 부탁드리며
extendsize함수를 보면 int** parr로 되어있던데... 더블 포인터가 들어가야되는이유라도?
}
index++;
}
for(i=0;iindex;i++)
{
printf(%d, , arr[i]);
}
free(arr);
return 0;
}
void extendsize(int** parr, int* psz)
{
int exsize=*psz+3;
int* temp =(int*)malloc(sizeof(int)*exsize);// 새로운 배열 생성
int i;
for(i=0;i*psz;i++)// 새로운 배열에 복사
{
temp[i]=(*parr)[i];
}
free(*parr);// 이전 배열 삭제
*parr=temp;
*psz+=3;
}
- 이 부분은 전체적인 부분으로 잘 모르겠더라구요.하나하나 설명 부탁드립니다.ㅠㅠ