inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

10.1 배열과 메모리

강의 11분 18초경 부분이 헷갈립니다.

213

kaisendon

작성한 질문수 15

0

교수님이 그리신 메모리 그림에서 100, 200, 300, 400 과 같은 주소는 설명을 위해 교수님이 임의로 집어 넣었다는 것이라고 말씀하셨는데요.

11분 18초에서 "첫번째 주소를 여기서 빼버려요" 라고 하고 숫자를 01234567.... 이렇게 바꾸시는데요. 이게 뭘 의미 하는건가요?

그리고 12분경의 "arr이 &arr[0]과 동일하다"라는 부분이 약간 이해가 안되네요. 문법적으로 &arr[0] (arr이라는 배열의 제일 첫번째 값의 주소) 이 그냥 arr이라고 써도 같다고 말씀 하시는 건가요?

c

답변 1

3

안소

안녕하세요.

- 배열의 인덱스는 (각 원소의 주소 - 첫번째 원소의 주소) / sizeof(int) 와 같다는 것을 보여주신 것입니다. 01234 가 인덱스입니다! 

- 배열의 이름엔 배열의 첫번째 원소의 주소가 담겨 있습니다. 배열의 이름인 arr 을 출력해보시면 arr[0] 첫번째 원소의 주소인 &arr[0]가 나오는 것을 확인하실 수 있을거에요! "배열의 이름엔 배열의 첫번째 원소의 주소가 담긴다!" 는 사실을 기억해주시면 될 것 같습니다. (그래서 배열 이름도 사실 포인터입니다.)

배열의 원소들은 메모리에서 다 이웃사이로 다닥다닥 다 붙어서 자리잡게 됩니다. 교수님께서 보여주신 그림처럼요! 그래서 배열의 크기와 배열의 첫번째 원소의 주소를 알면 배열의 나머지 원소들에도 접근을 할 수 있겠죠! 예를들어 int 배열이라면 arr[0]에서 4 * 2칸의 메모리칸만 더 가면 arr[2]가 있는 곳이라는 것을 바로 알 수 있습니다. 그래서 배열의 이름에 첫번째 원소의 주소가 들어가는 것입니다. &arr[0]와 arr배열이 크기가 4라는 것만 알아도 arr배열의 모든 원소에 다 접근할 수 있고, 배열이름에 첫번째 원소의 주소가 들어가기 때문에 우리는 arr[0] arr[1] 이런식의 배열의이름[인덱스] 형식으로 원소들에 접근할 수 있다는 원리입니다.

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

1

50

3

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

1

54

2

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

1

53

2

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

1

46

1

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

1

72

2

12.12 헤더 관련 질문

1

59

2

Visual Studio Community 2026 사용 문의

1

136

2

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

1

59

2

getchar(), putchar()

1

92

3

강의자리ㅛ

1

78

2

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

1

112

2

소스파일안에 여러 파일

1

75

2

F5와 F7의 차이

1

75

2

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

1

58

2

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

1

68

1

Step over 기능 문의

1

52

2

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

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

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

1

62

2

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

1

64

2

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

1

53

2

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

1

53

2

11.5 코드 구현

1

67

2