utf-8, char
51
21 asked
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();
Answer 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 타입이 어떻게 활용되는지 간접적으로 이해하는 데 도움이 될 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
RequestHandler 버전 간 process() 파라미터 차이 질문
0
69
2
리플렉션 default
0
51
1
그럼 SOURCE나 CLASS는 어떤 경우에 사용하나요?
0
75
2
네트워크 프로그램 자원종료 Socket 정리 시 closed 사용 문의
0
99
2
FileInputStream의 transferTo 사용 시 Buffer 문의
0
63
1
오타 제보 드립니다
0
73
2
강좌 복습 팁이 있으신 분들 공유해주시면 감사하겠습니다.
0
104
1
16강 질문있습니다.
0
48
1
한글이 깨질 떄 어떻게 해야 하나요?
0
78
1
자원 정리시 에러가 발생 했을 때 메모리 상황 및 실무에서 로그 확인 방법
0
90
1
인텔리제이에서 네모(스탑버튼) 누르는 것의 의미
-1
66
1
강의 섹션 8: 네드워크 -프로그램 3부분 10:45 오타?
0
86
2
제대로 이해한게 맞나 궁금합니다
0
77
1
File,Files 강의 2번쨰 Files 07:30 에 tmep 파일들을 다 지운건가요 ?
0
61
1
/.well-known/appspecific/com.chrome.devtools.json 에러에 대해서
0
613
1
Socket 자원을 정리할때 stream 을 정리하지 않는 이유가 궁금합니다.
0
89
1
클라이언트 강제종료시 오류 메세지
0
106
2
고급 2편에는 퀴즈가 없네요?
0
97
1
55. 네트워크 프로그램5 - 자원정리2 질문
0
67
1
클라이언트가 FIN과 함께 보내는 ACK는 무엇에 대한건가요?
1
105
2
BufferedInputStream이 1바이트씩 조회해도 성능이 좋은 이유
0
79
1
오타제보
0
59
2
문자 집합 호환성 여부를 판단할 때
0
51
1
RequestBody를 읽어올 때
0
68
2

