Inflearn brand logo image

인프런 커뮤니티 질문&답변

티티티님의 프로필 이미지
티티티

작성한 질문수

김영한의 실전 자바 - 고급 2편, I/O, 네트워크, 리플렉션

문자 인코딩 예제2

utf-8, char

작성

·

26

·

수정됨

0

utf-8로 지정해서 IO 작업을 하더라도,
utf-16인 (char)로 형 변환이 가능한 이유가 궁금합니다.

 

char는 ascii와 호환이 안되지않나요..?

StringBuilder content = new StringBuilder();

FileReader fr = new FileReader(FILE_NAME, UTF_8);

int ch;
while ((ch = fr.read()) != -1) {
content.append((char) ch);
}
fr.close();

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 티티티님께서 질문해주신 내용에 대해 알아보겠습니다.

UTF-8과 UTF-16은 각각 다른 유니코드 인코딩 방식입니다. UTF-8은 가변 길이, UTF-16은 고정 길이(2바이트) 인코딩을 사용합니다. 그럼에도 불구하고 자바에서 char 타입은 16비트 유니코드 문자를 표현할 수 있기 때문에 UTF-16과 직접적인 호환성을 가지고 있습니다.

자바에서 파일을 읽을 때, 보통 Reader를 통해 UTF-8로 인코딩된 파일을 읽고 char 형태로 변환하여 처리하게 됩니다. 여기서 중요한 점은, 파일 시스템에서 읽어들인 UTF-8 데이터를 자바 내부에서 처리할 때 char로 캐스팅되면서 UTF-16으로 해석된다는 것입니다. 이것이 가능한 이유는 Reader가 데이터를 읽을 때 UTF-8을 자바가 이해할 수 있는 UTF-16으로 변환하기 때문입니다. 이렇듯 자바 내부에서는 모든 문자 데이터가 유니코드(UTF-16)로 처리되어 있으므로 문제 없이 형 변환이 가능합니다.

이 과정을 통해 자바는 다양한 인코딩된 텍스트 데이터를 유니코드 형식으로 통일하여 처리할 수 있게 됩니다.

관련된 예시와 설명을 보실 수 있는 다른 질문 게시물도 확인해보시면 도움이 될 것 같습니다:

  • String이 불변 객체인 이유 질문에서는 자바의 문자열 처리와 관련된 기본 개념을 설명합니다. 여기서는 String의 불변성과 내부 처리 방식에 대해 논의하고 있어, char 타입이 어떻게 활용되는지 간접적으로 이해하는 데 도움이 될 수 있습니다.

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

티티티님의 프로필 이미지
티티티

작성한 질문수

질문하기