inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

김영한의 실전 자바 - 중급 2편

직접 구현하는 배열 리스트2 - 동적 배열

직접 구현 하는 배열리스트2 - grow() 에서 질문이요

해결된 질문

139

생각하는자

작성한 질문수 139

0

 학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.


1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
안녕하세요. 강의를 들으면서 궁금증이 생겨서 질문을 남깁니다.

grow 라는 메서드를 통해서 동적 배열의 사용법을 잘보았습니다.

전에 강의에서(어떤 강의인지는 기억 안남.) 영한님이 10억 이라는 숫자를 말씀 하신 걸로 기억을 합니다.

이 10억 이라는 숫자 때문에 질문이 생깁니다.

어떤 배열에 데이터를 넣다 보니 , 최대 데이터 용량이 18억건의 데이터를 넣을수 있게되었습니다.

그런데 어찌저찌 하다 보니 그 데이터 배열이 꽉 차서 50%를 배열의 길이 늘린다고 가정 했을 때, 대략 (18+9 = 27) 27억 이라는 배열의 길이가 나옵니다.

근데 여기에서 int형 범위 가 생각납니다. 검색해보니 약 22억 '+,-' 이더 라고요.

이런 경우에는 어떻게 처리를 하나요?,

아니면 이런 경우는 아에 없고, 데이터의 크기가 너무 크니, 어떠한 숫자의 상한선이 되면, 다른 객체 배열을 만드나요?

(2번째 경우는 글 쓰면서 생각이 나네요)

답변 부탁 드립니다.

java 객체지향 코딩-테스트 알고리즘

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 생각하는자님.

동적 배열과 관련된 grow() 메서드에 대한 질문을 주셨군요. 많은 양의 데이터를 처리할 때, 배열의 성장 한계와 관련된 문제는 자바에서 흔히 다뤄지는 주제입니다. 특히, int형으로 최대 커버할 수 있는 크기, 약 21억(2^31 - 1)의 한계치에 대한 걱정은 아주 타당한 질문입니다.

자바에서는 ArrayList와 같은 동적 배열의 내부 구현에서 실제로 이와 같은 문제가 발생할 수 있으며, 자바의 ArrayList는 내부적으로 int[]로 데이터를 관리하고 있기 때문에, 이 범위를 넘어가는 경우 문제가 발생할 수 있습니다.

해결 방안:
1. 데이터 분할 및 샤딩: 거대한 배열이 필요하다면, 데이터를 여러 배열로 나누거나 데이터베이스와 같은 외부 저장소를 사용할 수 있습니다.
2. Long 자료형 및 Java의 BigInteger 사용: 대부분의 경우, 배열의 인덱싱이 아닌 값을 표현할 때 Long 자료형을 사용하는 것이 적절합니다. 그러나 직접 관리해야 하는 경우가 아니라면 자료형의 범위를 넘어서는 문제는 컬렉션 프레임워크에서 자동으로 해결됩니다.
3. 외부 저장 체계: 만약 데이터의 양이 방대한 경우, 메모리 내에서 유지하기 보다는 데이터베이스 시스템이나 파일 시스템을 이용하는 것이 좋습니다.

이와 관련된 자세한 내용과 예시는 이미 이전 질문에서 다루어진 바 있습니다.

추가적으로 궁금한 부분이 있다면, 이어서 질문해 주시기 바랍니다. 지식공유자님이 더 상세한 답변을 제공해주실 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

제네릭 타입 매개변수 제한과 관련한 문의입니다.

0

80

3

강의가 좀 버겁다 느껴질 때 학습방법 문의

1

135

4

제네릭 반환값 및 파라미터 선언 방식의 변화 <T> T

0

62

1

new T()가 안 되는 니유

0

102

1

안녕하세요, 문제와 실행 결과가 다른 부분이 있어 제보드립니다.

0

98

2

자바 로드맵 선택 질문

0

111

2

실전 자바 중급 - 2편 후 추천 강의

0

176

2

실프로젝트에서 Java25버전 사용

0

121

1

Arrays.sort

0

68

1

블로그 작성 시, 저작권 문제에 대하여

0

166

1

중급2편 56강의 bucket.add(value); 메서드가 이해가 안됩니다.

0

94

3

pop()과 poll()의 차이

0

94

1

특정 index의 노드 조회하기 질문

0

66

2

List.of() 비어있는 불변 리스트 생성

0

81

2

문제2: 개 타입 반환

0

56

2

[리뷰] 중급2편까지 겨우 완강 했습니다.

0

114

2

문제와 풀이1 Ex2와 Ex3

0

65

2

노드 삭제시 노드 null값으로 초기화

0

77

2

강의영상에 대한 질문

0

57

1

타입 매개변수 제한

0

59

1

compareTo

0

68

1

직접 구현하는 연결리스트 3 - 추가 부분 질문있습니다

0

99

3

섹션 8-58 equals and hashcode 에서 코드가 다르게 생성됨

0

70

2

퀴즈 오류 관련 문의

0

109

1