inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

10.5 2차원 배열과 메모리

ptr[k]는 *(redirection)의미를 내포하고 있는것인가요 ?

해결된 질문

260

이시현

작성한 질문수 14

8

교수님 오랜만에 질문남깁니다. 바쁘시다면 맨 아래 질문을 요약해 두었습니다.

int main()

{

       int arr[2][3] = { {1,2,3}, {4,5,6} };

        int* ptr = &arr[0][0];

for (int k = 0; k < 6; ++k)

printf("%d ", ptr[k]);

printf("\n\n");

printf("%zd %zd\n", sizeof(arr), sizeof(arr[0]));

printf("\n");

}

8분대에 위 코드를 설명해주실 때 ptr[k]를 보면서 ptr앞에 *가 없으니 주소가 출력되겠구나 생각하고 있었는데, 1,2,3,4,5,6이 출력되어서 혼동이 왔습니다. 

int *ptr = &arr[0][0]으로 ptr은 arr의 메모리 주소를 가지고 있고 ptr[k]에서 *를 달아주지 않았음에도 arr의 배열Value를 출력시키고 있는것은 ptr[k]에서 자동적으로 redirection을 해주고 있는것인지 궁금합니다.

*가 생략된걸까 해서 *ptr[k]도 똑같이 작동하지 않을까? 해서 시도 해보았으나 피연산자 오류가 떴습니다. ptr[k]는 포인터가 아님을 컴파일러가 지적해 준것 같습니다.

포인터의 index기능?(이 단어가 맞는지 모르겠습니다)을 혹시 설명해 주셨는데 제가 놓친건지요..?

질문을 간단히 요약하겠습니다.

Q. printf("%d ", ptr[k]); 에서 *이 없음에도 array의 value가 출력되는 것은 ptr[k]에 indirection 기능이 내포된 것인가요 ? 

감사합니다. 

c

답변 3

3

홍정모

간단히 정리하면 2차원도 내부적으로는 메모리에 1차원 배열 형태로 저장되고 위의 포인터는 그 주소를 가져오기 때문에 1차원 배열처럼 인덱싱하는 겁니다. 다차원 배열 인덱싱은 동적할당에 나와요.

3

홍정모

혼동하기 쉬운 부분이네요. Indirection을 내포하고 있다기 보다는 메모리 주소 체계를 생각해보면 2차원 배열도 결국은 내부적으로는 1차원배열이라는 점과 연결시키셔야 합니다. 동적할당 메모리를 다차원 배열처럼 사용하는 방법에 대한 강의를 참고하시면 도움이 될 것 같습니다.

0

이시현

답변 감사드립니다. 이후 뒷부분 강의 내용 참조가 필요하군요. 조금 더 수강하다보면 궁금증이 해결되겠습니다. 감사합니다.

Export template 안됨

1

19

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

54

3

main 함수에서 왜 int만 선언이 되는걸까요

1

56

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

54

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

49

1

프로토타입과 함수간의 인자 불일치

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

137

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

61

2

getchar(), putchar()

1

93

3

강의자리ㅛ

1

80

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

113

2

소스파일안에 여러 파일

1

76

2

F5와 F7의 차이

1

76

2

c = TWO * (a+b); 에서 a와 b는?

1

58

2

; 세미콜론을 붙이는 기준에 문의

1

70

1

Step over 기능 문의

1

53

2

2.6 강의 따옴표 출력 규칙 문의

1

75

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

61

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

65

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

53

2