Running następujący (przykład) KodJava InputStream kodowania/charset
import java.io.*;
public class test {
public static void main(String[] args) throws Exception {
byte[] buf = {-27};
InputStream is = new ByteArrayInputStream(buf);
BufferedReader r = new BufferedReader(
new InputStreamReader(is, "ISO-8859-1"));
String s = r.readLine();
System.out.println("test.java:9 [byte] (char)" + (char)s.getBytes()[0] +
" (int)" + (int)s.getBytes()[0]);
System.out.println("test.java:10 [char] (char)" + (char)s.charAt(0) +
" (int)" + (int)s.charAt(0));
System.out.println("test.java:11 string below");
System.out.println(s);
System.out.println("test.java:13 string above");
}
}
daje mi to wyjście
test.java:9 [byte] (char)? (int)63 test.java:10 [char] (char)? (int)229 test.java:11 string below ? test.java:13 string above
Jak mogę zachować prawidłową wartość bajtów (-27) w line-9 wydruk? I w konsekwencji otrzymaj oczekiwaną moc wyjściową polecenia System.out.println(s)
(å).
s.getBytes ("ISO-8859-1") załatwił sprawę, dziękuję. Używałem go tylko do śledzenia miejsca, w którym czytana zawartość pliku zmieniła się w ścieżce, od czytania pliku do prezentacji danych użytkownikowi. – Tobbe
@Tobbe: Cieszę się, że pomogło. W przyszłości lepiej byłoby nie przekształcić go w tekst. Chyba, że to naprawdę * jest * zakodowany plik tekstowy ISO-8859-1, oczywiście. –