String in Hex konvertieren: Problem

Status
Nicht offen für weitere Antworten.

bonesix

Mitglied
Hi,

ich lese gerade aus einer MaxDB ein Feld vom Typ CHAR() BYTE aus. In meinem SQL Fenster steht in diesem Feld der Wert CA04408C8B633C76B8844607C477. Auslesen tue ich das bei meinem ResultSet als String (gibts da ne sinnvollere Lösung?)

Wenn ich von Hand (im Windows-Rechner ;-)) die Zahlen aus dem String wieder in Hex umwandeln will kommen nur bei 80% richtige Zahlen raus.

HEX = Hexadezimale Zahl, wie sie im SQL Fenster angezeigt wird
HEX>DEZ = Umwandlung in Int mit dem Windows Taschenrechner
SQL = eigene Umwandlung per Code

Code:
HEX  HEX>DEZ  SQL
CA	202		202	OK
04	  4		  4	OK
40	 64		 64	OK
8C	140		338	FALSCH
8B	139     8249	FALSCH
63	 99		 99	OK
3C	 60		 60	OK
76	118		118	OK
B8	184		184	OK
84	132     8222	FALSCH
46	 70		 70	OK
07	  7		  7	OK
C4	196		196	OK	
77	119		119	OK

Alle bis auf die 3 Hexzahlen die mit 8 anfangen sind korrekt. Nur warum sind die 3 falsch?

Hier mein Code:
Code:
String test = results.getString(colNames.get("OBJECTID"));
for (int x = 0; x < test.length(); x++) {
	char c = test.charAt(x);
	System.out.println((int)c);
}

Wird der String ohne Umwandlung ausgegeben kommt Ê@Œ‹c<v¸„FÄw ¿ heraus. Also erstmal unbrauchbar zum anzeigen und weiterarbeiten.

Hat jemand eine Idee, warum das bei diesen 3 Zahlen nicht funktioniert?

Viele Grüße und danke im vorraus,
ms
 
S

SlaterB

Gast
wenn du diesen String ausgibst kommt son Quatsch raus, und wenn ihn zeichenweise ausgibst wird daraus "338"??

also das für sich würde mich schon mehr wundern als ob da nun 338 oder 140 rauskommt ;)

oder ist der gesamte String 'CA04408C8B633C76B8844607C477' gleich dem 'Ê@Œ‹c<v¸„FÄw ¿'?

mit fällt nun noch nichts direkt ein, aber teste vielleicht mal mit DB-Elementen '1', '2', '3' usw.,
insbesondere natürlich die 8
 

bonesix

Mitglied
Hi,

ja, der gesamte String 'CA04408C8B633C76B8844607C477' ist gleich dem 'Ê@Œ‹c<v¸„FÄw ¿'. Das liegt vermutlich daran dass die Hexzahlen im String als ASCII Zeichen interpretiert und ausgegeben werden. Und dann kommt da eben so ein seltsamer String bei raus.

Da ist es schon eher verwunderlich dass die Int-Zahl überall ausser an 3 Stellen funktioniert. Würde das funktionieren kann ich die Dezimaldarstellung problemlos in einen Hex-String zum Anzeigen konvertieren. So geht es aber leider nicht.

Grüße,
ms
 

Marco13

Top Contributor
Irgendwie glaube ich nicht, dass das mit der führenden "8" zu tun hat - eher damit, dass die Zahlen, die falsch sind, alle größer sind als 255, und damit nichtmehr mit einem byte dargestellt werden können...
 

Tellerrand

Bekanntes Mitglied
Marco13 hat gesagt.:
Irgendwie glaube ich nicht, dass das mit der führenden "8" zu tun hat - eher damit, dass die Zahlen, die falsch sind, alle größer sind als 255, und damit nichtmehr mit einem byte dargestellt werden können...
Die sind doch nur größer als ein byte eben weil sei falsch sind.
CA z.B. die höchste verwendete Zahl hier ist korrekt.

Wunder mich eher darüber,d ass hier so viel murks passiert beim String aus der Datenbank lesen.
Der Code:
Code:
String test = results.getString(colNames.get("OBJECTID")); 
for (int x = 0; x < test.length(); x++) { 
   char c = test.charAt(x); 
   System.out.println((int)c); 
}
wegibt für mich irgendwie keinen Sinn, was soll der machen?

Und an welcher Stelle wandelst du in Hex um?
 

bonesix

Mitglied
In die Richtung gingen meine Gedanken auch schon.
Nur: 8B ist eigentlich 139, also unter 255. Bei B8 (184), einer größeren Zahl gehts ja auch.

Oder habe ich irgendwo einen Denkfehler drin?
 

bonesix

Mitglied
Tellerrand hat gesagt.:
Und an welcher Stelle wandelst du in Hex um?

Noch garnicht.
Ich lade den Wert als String aus der DB. Danach iteriere ich über alle Chars in dem String und wandle den Char in einen Integer um und gebe ihn aus. Die Ergebnisse entsprechen der dritten Spalte SQL (erstes Posting).

Danach erst sollen die Zahlen in Hex umgewandelt werden. Dieser Code existiert aber noch nicht, da ja bereits die Umwandlung in die Dezimaldarstellung nicht korrekt zu funktionieren scheint.

Meiner Ansicht nach müssten diese Integer dem Dezimalen Wert der Hexzahl entsprechen (korrigiert mich bitte wenn das nicht so ist). Was bei allen ausser 3 Zahlen auch der Fall ist.
 
S

SlaterB

Gast
> Meiner Ansicht nach müssten diese Integer dem Dezimalen Wert der Hexzahl entsprechen

warum sollte das eigentlich so sein?
schön und gut falls die DB automatisch nach Dezimal umwandelt,
aber warum sollte die das für jede Ziffer einzeln machen?
 

Marco13

Top Contributor
Hol' dir das ganze doch mal mit reault.getBytes als bytes array. Dann hast du (vermutlich) auch keine Problem mit Zeichen, die im String als Unicoed interpertiert werden :wink:
 

bonesix

Mitglied
Ahhh ich habs:

@Marco13:

Ja man muss getBytes() benutzen. Das hatte ich schonmal versucht war aber etwas verwirrt weil dann auch negative Zahlen herauskommen. Allerdings kommen die Bytezahlen in einer Zweierkomplementdarstellung an, d.h. alles > 125 wird in den Bereich -125 bis 0 verschoben.
Das hat mich anfangs etwas verwirrt^^

Thx und bye,
ms
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
C String zu Int konvertieren Allgemeine Java-Themen 9
M ArrayList mit verschiedenen Datentypen in String konvertieren Allgemeine Java-Themen 10
B .txt Datei in einen kompletten String konvertieren Allgemeine Java-Themen 20
C String in double[][] konvertieren! Allgemeine Java-Themen 5
P Datentypen String-Daten zu Byte-Zahlen konvertieren - Komme nicht weiter nach vielem versuchen :-/ Allgemeine Java-Themen 7
J String mit "," in Double Wert konvertieren Allgemeine Java-Themen 7
S byte [] in string und zurück konvertieren Allgemeine Java-Themen 2
R byte[] to String Konvertieren Allgemeine Java-Themen 14
T Interger in String konvertieren Erklärung benötigt Allgemeine Java-Themen 11
G Array/String aus Request wieder in Array konvertieren Allgemeine Java-Themen 2
T ArrayList in String[] konvertieren. Allgemeine Java-Themen 3
M Value als String in beliebige Klasse konvertieren Allgemeine Java-Themen 18
R StringWriter konvertieren in einen String !!! Allgemeine Java-Themen 2
C EML Email Text in String wandeln Allgemeine Java-Themen 11
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
JAnruVA Datentypen Berechneten String-Wert in Double umwandeln um weiter zu rechnen Allgemeine Java-Themen 7
M String Allgemeine Java-Themen 10
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
O String in Long Hexerdezimal umwandel Allgemeine Java-Themen 14
N String vergleichen. Allgemeine Java-Themen 27
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
SaschaMeyer Arbeitet String.split falsch? Allgemeine Java-Themen 4
M Switches ohne String Allgemeine Java-Themen 18
AmsananKING String Iteration Allgemeine Java-Themen 5
S Shuffle String aus if-clause Allgemeine Java-Themen 11
Besset Variablen Ist String = "" + int inordnung? Allgemeine Java-Themen 6
M Map <Long, String> zu Map<String, Long> Allgemeine Java-Themen 9
I String Encoding Verständnisproblem Allgemeine Java-Themen 22
N Prüfen, ob ein String 2x das selbe Zeichen hat Allgemeine Java-Themen 10
SaftigMelo Bug Fixen von String-spliten Allgemeine Java-Themen 8
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
YohnsonM String - Aufteilung und Nutzung einzelner Chars Allgemeine Java-Themen 7
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
S String umbenennen: wie? Allgemeine Java-Themen 4
x46 String Format Fehler Allgemeine Java-Themen 2
S ISO 8601 -> getter / setter String Allgemeine Java-Themen 3
L String zu repräsentativen Wert Allgemeine Java-Themen 0
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
L regex ganzer string? Allgemeine Java-Themen 2
L Ist ein string ein erlaubter variabel name? Allgemeine Java-Themen 2
Z JNA Cpp-DLL String Verwendung Allgemeine Java-Themen 2
A String auf Zahlen überprüfen Allgemeine Java-Themen 5
N String Array Eingabe Allgemeine Java-Themen 6
MiMa Datum von String zu LocalDateTime Allgemeine Java-Themen 8
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
R char aus String entfernen Allgemeine Java-Themen 10
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Ini Text aus String parsen Allgemeine Java-Themen 1
T String-Manipulation beim Ablauf in Eclipse und als JAR-File Allgemeine Java-Themen 8
M String lässt sich nicht Zusammenfügen Allgemeine Java-Themen 10
Drachenbauer Wie kann ich das Wort "concrete" in einem String durch ein anderes Wort ersetzen lassen? Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
R Variablen String mit split-Funktion aufteilen Allgemeine Java-Themen 7
F Datei in String-Array einlesen Allgemeine Java-Themen 8
S Marker aus String ermitteln Allgemeine Java-Themen 5
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
M Bei String.format ein Komma statt einem Punkt ausgeben lassen Allgemeine Java-Themen 1
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J String - Vergleiche Allgemeine Java-Themen 7
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
G CSV in String Allgemeine Java-Themen 7
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
D Erste Schritte Fehler mit negativen und 0 Zahlen im String Allgemeine Java-Themen 6
Xge Replace x Zeichen aus String Allgemeine Java-Themen 2
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
F In String 2 Buchstaben vertauschen Allgemeine Java-Themen 2
J Class Decompile als String (Procyon) Allgemeine Java-Themen 2
I Datentypen String in class sicher verwahren Allgemeine Java-Themen 17
J Falls der String ein "X" beinhaltet Allgemeine Java-Themen 2
T String mehrere Worte Allgemeine Java-Themen 2
D String Groß-/Kleinschreibung Allgemeine Java-Themen 2
D String und Klassenvariable Allgemeine Java-Themen 6
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
C String in Objektnamen umwandeln Allgemeine Java-Themen 3
E Variablen Aus .txt ausgelesener string mit if() überprüfen? Allgemeine Java-Themen 2
L String-Schema-Aufspaltung Allgemeine Java-Themen 2
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
L String splitten und multiplizeren Allgemeine Java-Themen 10
G String mit umbekannter länge splitten. Allgemeine Java-Themen 2
S Einzigartigen String in Datenbank finden und löschen Allgemeine Java-Themen 23
A Byte zu String Allgemeine Java-Themen 4
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
T Komplexitätsoptimierung String vergleich Allgemeine Java-Themen 4
heinz ketchup String im JLabel ausgeben und erneuern Allgemeine Java-Themen 6
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
L Decrypt String Allgemeine Java-Themen 1
X Variablen AtmicLong größer als String ? Allgemeine Java-Themen 4
S String literal und Referenzvariablen Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben