작성
·
245
0
int* ptr = &arr[0][0];
for (int k = 0; k < 6; k++)
printf("%d", ptr[k]);
printf("\n\n");
여기서 ptr이라는 포인터 변수에는 arr[0][0]의 주소값이 들어가 있다고 이해했습니다.
1.그러면 printf에서 ptr변수에 저장되어 있는 주소에 저장되어 있는 값을 불러오려면 *가 필요한것 아닌가요?
2.또한 ptr에 왜 [k]같은 indexing 구조가 가능한지 모르겠습니다. ptr를 arr[0][0]의 첫번째 주소 그 자체 혹은 arr[0][0]의 값, 둘중 어느식으로 이해를 해도 ptr가 마치 배열처럼 기능하는 것이 이해가 잘 안됩니다. ptr에는 하나의 값만 저장되어 있는 것 아닌가요??
감사합니다
답변 1
1
안녕하세요,
말씀해주신 두 개의 질문은
이차원 배열이 내부적으로 어떻게 저장되는지
이해하시면 모두 해결될 것이라 생각합니다.
아래와 같이 일렬로 저장됩니다.
아래 링크를 참고해보세요.