배열의 메모리공간,요소의공간 의미가 좀 햇갈립니다..
마호
질문 제목 : 배열의 메모리공간,요소의공간 의미가 좀 햇갈립니다..배열의 메모리공간,요소의공간 의미가 좀 햇갈립니다..질문 내용 :
안녕하세요..
서적을보면
arr는 상수이며 선언한 배열의 첫번째 요소만 가리킨다.
이렇게돼있는데요.
선언된 배열 arr 과 첫번째요소 모두다 &연산자를 이용하면 주소값이 동일하더라구요..
위그림을보시면 arr 과 포인터b가 0번요소를 가르키고있습니다..
이렇게돼면 arr이 0번을 가르킨다.. 말이되는데..
위그림만보면 배열,요소들,포인터변수 모두다 각각의 메모리고유주소값이 존재할것처럼보이는데..
#include stdio.h
int main(void)
{
int a[3]={10,1,2};
printf(a자체주소값:%d \n,&a);
printf(a가 가르키는 주소값: %d \n,a);
printf(a[0]번주소값:%d \n,&a[0]);
printf(a[0]번값:%d \n,a[0]);
return 0;
}
결과
---------- run ----------
a자체주소값:1245044
a가 가르키는 주소값: 1245044
a[0]번주소값:1245044
a[0]번값:10
출력 완료 (0초 경과) - 정상 종료
배열의 자체주소값과 0번요소의 주소값이 같다는 결과가나오더라구요..
첫번째 그림은 독자를 편하게 이해시키기위한 그림이었는지..
아니면 실제 arr 과 0번요소의 메모리공간이 서로 독립적인것인지..
혼란이옵니다..
-
다스리
아자꾸 리플달렸다고 나오길래 와보니깐 스펨리플이 달리네요.. 근데 리플삭제도 순식간이군여;;
-
재미
음..두분답변 감사드립니다..
답변을 보고 생각해봐야겠습니다. -
퐁당
a[3] 배열에서 a는 a배열의 시작 주소를 나타내고요
당연히 a배열의 시작 주소는 a[0]이죠 그래서 같은 주소 값이 출력 됩니다.
만약 (a+1) 이라고 하시면 시작주소에서 그 배열의 자료형만큼 주소가 이동 되는거죠
a = &a[0]
(a+1) = &a[1]
(a+2) = &a[2]
동일한 주소로 보시면 되요
*a = a[0]
*(a+1) = a[1]
*(a+2) = a[2]
서로 달라보이지만 결론은 동일한 값을 출력 하죠 ㅋ
또한 int -
에드문드
심볼a는 사실상 편의를 위한 심볼이고, 그 자체로 a[3]이란 정적배열을 대표합니다.
따라서 심볼 a의 주소값은 &a[0]과 같고, 배열은 곧 포인터이기 때문에 a가 가르키는 주소값을 찍으면 &a[0] 즉 a[3]이란 정적배열의 대표주소값이 찍히게 됩니다.
근본적으로 정적배열과 동적배열은 매커니즘상 거의 동일 합니다만, 실제적으론 둘은 미묘하게 다르며 정적배열은 컴파일 타임에 컴파일러가 할수 있는 모든 짓을 다 해놓기 때문에 저렇게 심볼a와 a[0]의