작성
·
203
0
코드 21번째 줄과 23번째줄 25번쨰 줄이 잘 이해가 안되네요.
현재 코드에서 pt는 a single pointer to one int니까 배열내의 int원소 한개의 주소를 가리키는&ar1[0][0]는 가능 하다는것이 납득이 됩니다.
그런데 23번째 줄에서 ar1[0] 같은 경우 왜 pt에 대입이 가능한가요? ar[0]는 a pointer to [3] int 아닌가요? 그러면 a single pointer to one int와는 타입이 다르니까 pt에 대입이 되면 안될거 같아요.
그리고 25번째 줄에서 ar1이 대입이 안되는 이유는 ar1은 pointer to [2][3] int라서 안되는건가요?
그리고 한가지 더궁금한게 왜 ar1[0]이게 a single pointer to single int가 되는건가요? 이차원 배열에서 첫번째 row를 가리키고 있으니까 오히려 a single pointer to 3 int가 맞지 않나요?
답변 1
2
안녕하세요!
오른쪽 보시면 확인할 수 있는데 ar1[0]은 int[3] 을 가리키는 포인터가 아닌 그냥 int[3]입니다. a pointer to [3] int가 아닌 a single pointer to one int 입니다. 즉 int[3] 배열의 첫번째 원소의 주소이니 int * 나 마찬가지라고 볼 수 있습니다. ar1은 이 int[3] 배열(int *) 타입인 ar1[0], ar1[1] 를 원소로 가지고 있는 배열이라고 생각하시면 됩니다. 그러니 ar1은 a pointer to [3] int 이자 그냥 int[2][3] 입니다.
배열의 이름은 첫번째 원소의 주소를 담는 다는 것을 상기해보시면, ar1 은 {ar1[0], ar1[1], ar1[2]} 배열의 첫번쨰 원소인 ar1[0]의 주소나 마찬가지입니다. ar1[0]은 {3, 0, 0} 배열의 첫번쨰 원소의 주소이므로, 즉 {3, 0, 0} 배열의 이름이므로 3의 주소를 담는 int * 이자 int[3] 입니다. ar1은 이 ar1[0]의 주소인 것이니 int[3] * 이자 int[2][3] 이라고 볼 수 있는 것입니다.
디버깅 해보시면 알 수 있는 부분이라 저번에 질문자님께 조언드린대로 디버깅을 꼭 해보셨으면 좋겠습니다. 메모리를 들여다보고 타입을 확인하고 이해하시는데 많은 도움이 될겁니다.😃 그리고 오늘 질문주신 부분 또힌 지난번에 드린 답글들로 답변이 되는 부분이라 지난 답글들을 다시 한번 읽어보시며(특히 링크 드렸던 이차원 배열의 구조 그림) 이해해보시길 권합니다.