작성
·
160
2
ptr[k]부분이 이해가 가질 않아서요...다른 분들이 올린 질문도 봤는데 2차원 배열도 결국엔 1차원으로 정렬된 메모리라는건 어느정도 이해가 된 것 같은데...포인터 옆에 [ ]를 붙이는 것이 간접 참조 연산자랑 같은 기능을 하는건지 궁금합니다..
답변 2
2
안녕하세요, 질문&답변 도우미 Soobak 입니다.
네, 같은 기능을 합니다.
ptr[k]
는 포인터 ptr
이 가리키는 위치로부터 k
개의 원소(자료형의 크기에 따라서)만큼 떨어진 위치에 있는 원소를 참조하며, ptr + k
포인터 연산과 같은 기능을 합니다.
강의 10.4 포인터와 배열 의 10:20 부분에서 관련 내용에 대해서 다루오니, 해당 부분만 잠시 복습해보시면 도움이 되실 것 같습니다.
0
안녕하세요, 인프런 AI 인턴입니다.
강진성님, C언어에서 포인터 옆에 대괄호 []
를 사용하는 것은 ‘인덱싱’이라는 개념으로, 배열에서 특정 위치의 원소에 접근하는 방식입니다. 포인터에 대괄호를 사용하는 것은 포인터가 가리키는 주소에서 특정 위치로의 오프셋을 계산하여 접근하는 것을 의미하며, 이는 간접 참조 연산자 *
를 사용한 것과 유사한 기능을 합니다.
다음은 강의에서 관련된 내용을 다루고 있는 유사한 질문과 그에 대한 답변 링크입니다:
int* ptr = &arr[0][0];
를 선언한 후, ptr[k]
에서 *
가 생략되었음에도 값이 출력되는 것에 대해 혼동이 왔다는 내용입니다. 강의의 지식공유자께서는 2차원 배열도 내부적으로는 1차원 배열처럼 메모리에 저장되어서 인덱싱이 가능하다고 설명하셨습니다.해당 질문과 관련된 답변을 참고하시면, 포인터 옆에 대괄호를 사용하는 문법에 대해 이해하실 수 있을 것 같습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.