6.12 동적 할당 배열 3:12
337
작성한 질문수 5
const int length = 5;
int arr[length];
이렇게 작성하는 것이 정적 할당 배열이고,
int length;
cin >> length;
int* arr = new int[length];
이렇게 작성하는 것은 동적 할당 배열로 이해했습니다.
그런데 int* arr = new int[length]; 를 이해하는 것이
너무 어렵습니다.
여기서 *는 메모리의 주소를 담는 변수인 포인터라는 의미로 알고 있는데,
그렇다면 int* arr= new int[length] 는 포인터가 배열인 것인가요...?
new 는 앞 강의에서 "자료형 사이즈에 맞게 메모리를 받아 온 다음 그 메모리 주소를 알려준다."라고 하셨고,,,,
실행을 해보니 new 와 *는 같이 있어야 하는 것 같네요,,,
앞에 배운 것이 뒤죽박죽 섞여서 혼란스럽네요,,
감사합니다.
답변 1
5
new 연산자를 사용하면 힙 메모리를 할당할 수 있고 새롭게 할당한 이 메모리의 주소를 리턴합니다. (new 의 리턴타입은 int* float* 이런 포인터인거에요)
메모리의 주소를 리턴하니 당연히 포인터에서 이를 받아야겠죠!
int[length] 👉 length 개의 int 원소들을 가진 배열
int * arr 👉 arr 은 int 원소의 주소값을 담을 수 있는 변수인 포인터
new 는 length 개의 int 원소들을 가진 배열을 힙 메모리에 동적으로 생성한 후, 이 메모리의 주소 (= 배열의 첫번째 원소의 주소)를 리턴하게 됩니다. 즉, 첫번째 원소(int) 의 주소를 리턴하는 것이기 때문에 int * 포인터에서 이를 받는 것이구요!
변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠
1
481
1
메모리 주소 10진수로 출력
1
672
1
클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.
1
515
1
여러가지 리턴 타입에 관한 강의가 어떤 걸까요?
1
549
1
메모리 주소에 관한 질분
0
687
1
인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.
0
558
1
형변환 오버로딩에서 const 관련 질문이 있습니다.
0
448
1
Digit 뒤에 reference를 사용하는 이유
0
512
1
4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결
0
325
1
dat파일이...
0
540
1
TODO:대입 연산자 오버로딩에 대한 소스코드입니다.
0
651
1
복사 생성자 관련 질문이 있습니다.
0
456
1
수업 중 궁금한점이 있습니다.
1
392
1
라이브러리자체가 이해가 되지 않습니다.
0
565
1
마지막 예제 질문
0
305
1
증감연산자 위치에 따른 수행 순서 질문입니다.
0
382
1
단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.
1
416
1
friend함수 관련 질문이 있습니다.
0
313
1
operator+ 정의부분에서 궁금한 것이 있습니다.
0
448
1
3분 17초 질문
0
354
1
함수에 값을 대입한다는 개념이 이해가 되지 않습니다.
0
450
1
int getvalue() const에서 const는 왜 뒤에 붙는건가요?
0
453
2
const Something &st에서 const를 빼면 안되나요?
0
304
1
friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??
1
495
1





