Frage zur expliziten Typumwandlung

Java_Newb

Mitglied
Hallo,
ich bin neu hier im Forum und hoffe, dass mir hier weitergeholfen werden kann.
Ich bin gerade dabei, die Typkonvertierung zu verstehen. Die implizite Typumwandlung habe ich (denke ich zumindest) verstanden. Hierbei wird ja einfach von einem kleineren zu einem größeren Wertebereich konvertiert.
Aber wie sieht es mit der expliziten Typumwandlung aus?
Wenn ich zum Bsp. habe:

float var = 512.7f + 100f;
byte b = (byte) var;


Wie gehe ich hier vor?

Bei der impliziten Typumwandlung gehe ich ja wiefolgt vor.
Bsp.:
byte var = (byte) 384;

Ich teile die Zahl 384 solange durch 2, bis ich die binäre Darstellung habe. Anschließend streiche ich alle Binärstellen bis auf die letzten 8 Bits weg. Das würde dann so aussehen: 1 1000 000 -> 1000 000. Jetzt rechne ich wieder in Dezimal um und erhalte -128.
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
Was bitte ?

der Wertbereich eines Bytes sind -128 bis + 127 das hat mit der Darstellung dieses Wertes nicht viel zu tun , du 'kannst' den Wert im zweierkomplement Schreiben, musst es aber nicht.

Ich versteh dein Problem nicht wirklich ?! Klär mich mal auf was genau das Problem ist ?!

Wenn du einem Primitiven Datentyp einen Wert zuweisen willst , der Größer ist als der Datentyp selbst, musst du Casten , damit der Compiler weiß , das du weißt was du da machst, alle Bits die größer sind als der Container werden abgeschnitten.

Umgekehrt kannst du einem Größeren Datentyp z.B vom Typ int, alle Werte zuweisen die kleiner sind als 32 bit, da sprich, short, char, byte....

Willst du z.b einen Wert den du als double vorliegen hast , einer Variable vom Typ int zuweisen , musst du casten. (64 -> 32 Bit, werden also 32 Bit abgeschnitten, und dein Wert wird ungenau, wenn du Pech hast)

zu deinem Beispiel oben

float(32bit) -> byte(8bit) | alle übrigen bits werden abgeschnitten.

oder willst du nur wissen wie du ins binärsystem umrechnest ?????


Ich teile die Zahl 384 solange durch 2

Das ist ein Trugschluss ^^ du modulo.....st xD


gelesen wird dann von unten nach oben Dezimalsystem -> Binärsystem
Code:
		128 mod 2 = 0
		 64 mod 2 = 0
		 32 mod 2 = 0
		 16 mod 2 = 0
		  8 mod 2 = 0
		  4 mod 2 = 0
		  2 mod 2 = 0
		  1 mod 2 = 1
		  
		  ergibt =  100000000 // -128 da java signed ist
		  ~      =  011111111 // +127
 
Zuletzt bearbeitet:

Java_Newb

Mitglied
Danke erstmal für deine Antwort.
Ich glaube, dass ich mein Problem nicht verständlich rübergebracht habe.
Es geht mir darum. Wenn ich zum Bsp. folgendes habe:

long ersteVariable = 784521678564217L;
int zweiteVariable = (int) ersteVariable;

Wie ermittle ich dann den Wert der zweiten Variable? Mir ist klar, dass long 64-Bit lang ist und int 32-Bit. Eine Möglichkeit wäre ja, 784521678564217 in Bit-Darstellung zu transfomieren und anschließend 32 Bit zu streichen. Dann hätte ich noch 32 Bits übrig und müsste diese einfach noch als Dezimalzahl umrechnen. Was ich eigentlich wissen wollte, ist, ob es denn nicht eine schnellere Methode gibt, um den gecasteten Wert zu ermitteln. Eine Zahl wie 784521678564217 erstmal in Binärdarstellung zu bringen, erfordert ja eine Menge Zeit. Geht das nicht schneller?

Mir geht es um das allgemeine Vorgehen bei der Zahlentransformation. Wie bestimme ich die gecastete Zahl?
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
Wie bestimme ich die gecastete Zahl?

Warum sollte man das wollten ^^ ?

und vorallem warum von Hand ? das übernimmt doch der Compiler/ die JVM schon für dich ?

Man führt diese art Cast nur da durch , wo man sich sicher ist was dabei raus kommt.

Ansonsten bleibt der Weg über die Umrechnung ins Binärsystem.

Du kannst dir dafür aber auch eine Methode erstellen ;)

oder du shiftest

Java:
public class Foo{

	public static void main(String[] args){
		
//		01111111_11111111_11111111_11111111 (32bit) 0x7FFFFFFF
		int a = 2147483647;	
		
		
//		01111111 (8bit)  0x7F	
		byte b = 127;		
		
		byte c = (byte) a;
		
//		left shift 31 stellen | -1 
		System.out.println((b << 31) - 1);  
		
//		Das entspricht -2147483648 - 1 = 32 Bit
	}
}

würde man hier b um 31 stellen nach rechts shiften , wäre die zahl negativ, da das vorzeichen bit belegt werden würde, deshalb auch -1.

Aber so richtig weiß ich trotzdem nicht warum man sich die mühe machen sollte dies von Hand zu errechnen ?!

Ansonsten schau mal ob dir das hier weiter hilft :

Typecasting

Da stehts auch nochmal erklärt wie das mit dem wegfallen der bits geregelt wird, ich vermute allerdings das dort ebenfalls auf binärer ebene bits gestrichen werden um auf den neuen Wert zu kommen.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Frage zum Quellcode - Zusammhänge und Ablauf. Java Basics - Anfänger-Themen 2
D Erste Schritte Frage eines absoluten Anfängers Java Basics - Anfänger-Themen 3
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben