ptr[k]는 *(redirection)의미를 내포하고 있는것인가요 ?
교수님 오랜만에 질문남깁니다. 바쁘시다면 맨 아래 질문을 요약해 두었습니다.
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 기능이 내포된 것인가요 ?
감사합니다.
답변 3
3
간단히 정리하면 2차원도 내부적으로는 메모리에 1차원 배열 형태로 저장되고 위의 포인터는 그 주소를 가져오기 때문에 1차원 배열처럼 인덱싱하는 겁니다. 다차원 배열 인덱싱은 동적할당에 나와요.
3
혼동하기 쉬운 부분이네요. Indirection을 내포하고 있다기 보다는 메모리 주소 체계를 생각해보면 2차원 배열도 결국은 내부적으로는 1차원배열이라는 점과 연결시키셔야 합니다. 동적할당 메모리를 다차원 배열처럼 사용하는 방법에 대한 강의를 참고하시면 도움이 될 것 같습니다.
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





