2차원 배열, 배열포인터 연산시 주소값 질문 드립니다!
큰마루
질문 제목 :
2차원 배열, 배열포인터 연산시 주소값 질문 드립니다!
질문 내용 :
//arr[i]==*(arr+i)
#include stdio.h
int main()
{
int arr[3]={1,3,5};
int *ptr1=arr;
int brr[3][2]={{1,2},{3,4},{5,6}};
int (*ptr2)[2]=brr;
printf(%d %d %d\n,arr[0],arr[1],arr[2]);
printf(%d %d %d\n,*arr,*(arr+1),*(arr+2));
printf(%d %d %d\n,brr[0],brr[1],brr[2]);
printf(%d %d %d\n,*brr,*(brr+1),*(brr+2));
return 0;
}
흠... 1차원 배열부분은... 이해가 됩니다..
제가 궁금한게 뭐냐면,
1차원배열에선 포인터상수인 배열이름을 가지고 포인터연산을 하며 각 배열 요소에 접근이 가능하지요?
물론 포인터 변수 ptr1에 이 포인터 상수인 주소값을 대입해주어 ptr1으로도 배열요소에 접근이 가능하구요.
다시 말해,
포인터 arr을 통해 연산을하며 배열과 동일한 위치를 가리키며 그 주소값존재 하는 값에접근이 가능합니다.
arr[0] 은 1이고, arr+0도 arr[0]의 주소값을 가지고 있고 *연산을 통해 그 주소값이 가지고 있는 값을 나타내구요. arr[1]은 2이고, arr+1은 arr[1]의 주소값을 가지고 있고 *연산을 통해 그 주소값이 가지고 있는 값이니 둘은 같구요,
그런데!!!
2차원 배열에선,
brr[0]은 행을 의미하게 돼잖습니까?그러면서 각 행의 첫번째 요소를 가리키고요,
그러니 brr[0]은 brr[0][0]의 주소값을 갖고 있는포인터 상수이지요?
그러니 brr[0]을 출력하면 주소값이 출력되는게 맞겠지요,
그런데, brr[0]==*(brr+0)이니 *(brr+0)도 주소값이 나와야 하는게 맞겠지요,
근데 전 이부분이 이해가 안갑니다.
brr은 2차원 배열의 첫번째 요소의 주소값을 갖고 있는 포인터 상수이잖아요? 배열전체를 의미하기도 하구요.
brr이 주소값을 가지고 있으니 여기에 대해서 *연산을 하면 1차원 배열 때와 동일하게 그 주소값에 있는 값이 나와야 하지 않느냐 입니다.
멘붕...입니다... 저의 궁금중을 풀어주시길 바랍니다.제가 1차적인 생각밖에 못하고 있는걸까요? 2차원배열에선 열까지도 있으니, 뭔가가 있는것인지, 질문을 적기도 너무 어렵네요...