Arithmetic Exception, obwohl nichts 0 ist

corvus

Mitglied
Hallo,

ich bräuchte mal Hilfe bei einer sehr speziellen Frage, auf die ich bisher keinerlei Antwort finden konnte.
Mein Code sieht folgendermaßen aus:
Java:
int requiredWidth = 320;
int scale_start=2;
		if (Runtime.getRuntime().maxMemory() > 64*1024*1024)
			scale_start=1;
int scale = requiredWidth <= 480 ? 2 : scale_start;
		debug("scale: " + scale);
		try{
			while(o.outWidth / scale / 2 >= requiredWidth)
				scale *= 2;
		}catch(ArithmeticException e){
			warn("Cannot calculate scale. Setting it to 2...", e);
			scale = 2;
		}
Jetzt kommt es manchmal dazu, dass eine ArithmeticException geworfen wird:
Code:
java.lang.ArithmeticException: divide by zero
. Soweit ja noch alles klar, dachte ich mir, ist "scale" halt eben komischerweise 0. Deshalb hab ich die debug-Nachricht davor eingebaut. Ergebnis: "scale" ist in allen Fällen 2! Und ab der Stelle hab ich keine Ahnung mehr :noe:
Meine beste Idee dazu wäre noch, dass Java - warum auch immer - in speziellen Fällen Variablen auf einen Standardwert (in diesem Fall wahrscheinlich 0) setzt, aber zu so etwas konnte ich nichts im Internet finden.
Ich weiß nicht, ob ihr den Fehler schonmal hattet, aber falls ja oder ihr auch sonst eine Idee habt, woran das liegen könnte, wäre ich sehr dankbar über eure Mithilfe :) Vielen Dank im Voraus für alle hilfreichen Antworten!
Viele Grüße
corvus
 

Joose

Top Contributor
Vor der Schleife ist es zwar 2, aber da der Wert in der Schleife geändert wird solltest du überprüfen welche Werte scale innerhalb der Schleife annimmt.
 
Zuletzt bearbeitet:

JCODA

Top Contributor
Es gibt den Fall, dass scale_start=1; ...(wegen der Memory)

dann kann scale 1 sein, wegen der requiredWidth.

In der Schleife scale mit Ganzzahlarithmetik durch 2 => 1/2 = 0 .
und dann teilst du outWidth durch 0.
 

Joose

Top Contributor
In der Schleife scale mit Ganzzahlarithmetik durch 2 => 1/2 = 0 .
und dann teilst du outWidth durch 0.

Hätte ich mir auch gedacht, bin mir da aber nicht ganz sicher, da meiner Meinung nach Java auch von links nach rechts rechnet.
Somit wird die Division o.outWidth / scale zuerst berechnet und dann erst durch 2 dividiert.
 

corvus

Mitglied
In diesem Fall liegt Joose richtig. Denn ich hab überhaupt nicht daran gedacht, dass sich scale ja auch in der Schleife ändern kann -.- Ich hab die Schleife also erstmal folgendermaßen umgebaut:
Java:
while(o.outWidth / scale / 2 >= requiredWidth){
	scale *= 2;
	debug("scale loop: " + scale + ", o.outWidth: " + o.outWidth + ", requiredWidth: " + requiredWidth);
}
Die Ausgabe sah dann ungefähr so aus:
Code:
12-18 09:26:54.630: D/GB::ImageHelper(546): scale loop: 4, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.631: D/GB::ImageHelper(546): scale loop: 8, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.632: D/GB::ImageHelper(546): scale loop: 16, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.635: D/GB::ImageHelper(546): scale loop: 32, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.636: D/GB::ImageHelper(546): scale loop: 64, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.637: D/GB::ImageHelper(546): scale loop: 128, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.639: D/GB::ImageHelper(546): scale loop: 256, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.641: D/GB::ImageHelper(546): scale loop: 512, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.643: D/GB::ImageHelper(546): scale loop: 1024, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.646: D/GB::ImageHelper(546): scale loop: 2048, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.651: D/GB::ImageHelper(546): scale loop: 4096, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.653: D/GB::ImageHelper(546): scale loop: 8192, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.661: D/GB::ImageHelper(546): scale loop: 16384, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.663: D/GB::ImageHelper(546): scale loop: 32768, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.666: D/GB::ImageHelper(546): scale loop: 65536, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.668: D/GB::ImageHelper(546): scale loop: 131072, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.683: D/GB::ImageHelper(546): scale loop: 262144, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.684: D/GB::ImageHelper(546): scale loop: 524288, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.686: D/GB::ImageHelper(546): scale loop: 1048576, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.687: D/GB::ImageHelper(546): scale loop: 2097152, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.689: D/GB::ImageHelper(546): scale loop: 4194304, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.690: D/GB::ImageHelper(546): scale loop: 8388608, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.696: D/GB::ImageHelper(546): scale loop: 16777216, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.697: D/GB::ImageHelper(546): scale loop: 33554432, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.698: D/GB::ImageHelper(546): scale loop: 67108864, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.700: D/GB::ImageHelper(546): scale loop: 134217728, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.701: D/GB::ImageHelper(546): scale loop: 268435456, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.703: D/GB::ImageHelper(546): scale loop: 536870912, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.704: D/GB::ImageHelper(546): scale loop: 1073741824, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.705: D/GB::ImageHelper(546): scale loop: -2147483648, o.outWidth: 1378, requiredWidth: 0
12-18 09:26:54.707: D/GB::ImageHelper(546): scale loop: 0, o.outWidth: 1378, requiredWidth: 0
Was ich nicht bedacht hatte: "requiredWidth" wird unter anderem anhand von zwei lokalen statischen Variablen berechnet, die zwar standardmäßig in der Klasse mit 0 initialisiert werden, aber eigentlich von einer anderen Klasse, die den genauen Wert dafür berechnet, folglich auch den richtigen Wert gesetzt werden. Bloß gab es dabei wohl manchmal einen Fehler, weshalb diese Variablen 0 blieben und requiredWidth auf 0 setzten, was zu diesem Überlauf führte. Ich hab das Problem jetzt erstmal damit gelöst, dass die zwei Variablen Standardwerte ungleich 0 haben. Bisher gab es damit noch keine Probleme.
Also, nochmal vielen Dank, Joose :)
Falls wir uns hier nicht mehr sehen, frohe Weihnachten und einen guten Rutsch an alle :)
Viele Grüße
corvus

P.S.: Ich find den Spoiler hier nie...
 

Joose

Top Contributor
Ich dachte schon an ein Problem mit dem Überlauf, nur war ich mir da nicht sicher ob er auf -214..... bleibt oder dann doch noch auf 0 springt ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Calendar/Date arithmetic Allgemeine Java-Themen 3
H Object cast exception Allgemeine Java-Themen 5
W Queue.remove() -> no such element exception Allgemeine Java-Themen 17
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
N Kann ich die Nullpointer Exception umgehen Allgemeine Java-Themen 12
N A java Exception has occured Allgemeine Java-Themen 8
G javafx "class path" exception Allgemeine Java-Themen 5
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
tom.j85 Exception bei Abfrage von Ländercodes in API? Allgemeine Java-Themen 13
S Exception Allgemeine Java-Themen 5
LimDul Streams und Exception Allgemeine Java-Themen 8
C FileLock - Exception wird immer geworfen Allgemeine Java-Themen 4
S Wertbeschränkung Exception oder Anpassung? Allgemeine Java-Themen 4
D Nullpointer Exception Problem Allgemeine Java-Themen 5
Kirby.exe Nullpointer Exception bei Queue Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
P Swing Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: npoints > xpoints.length || npoints > ypoints.length Allgemeine Java-Themen 5
S RMI Exception Allgemeine Java-Themen 0
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
S Interface, generischer Datentyp, Exception? Allgemeine Java-Themen 3
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
B Aufruf der Methode ergibt eine Exception Allgemeine Java-Themen 13
S Exception in thread "main" java.lang.NullPointerException at FamilienApp.main(FamilienApp.java:15) Allgemeine Java-Themen 1
M Klassen Serializable Exception Allgemeine Java-Themen 1
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
E Thread Exception Allgemeine Java-Themen 6
javaerd Binomialkoeffizient ausrechnen, Exception in thread "main" java.lang.StackOverflowError Allgemeine Java-Themen 6
M xlsx File auslesen Exception occured Allgemeine Java-Themen 13
X jvm exception abfangen und an externes Programm schicken Allgemeine Java-Themen 4
G Java/LibGDX File Loading Exception Allgemeine Java-Themen 2
B Exception in Application init method Allgemeine Java-Themen 5
H OOP Testen einer Exception mit JUnit Allgemeine Java-Themen 8
M javafx ComboBox- Nullpointer Exception Allgemeine Java-Themen 6
perlenfischer1984 Dialect class not found exception Allgemeine Java-Themen 15
Thallius Bekomme keine Exception mit Stacktrace mehr. Was habe ich getan? Allgemeine Java-Themen 13
perlenfischer1984 Functionsparameter prüfen und eine Exception werfen !? Allgemeine Java-Themen 11
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Z Exception wird nicht ausgelöst Allgemeine Java-Themen 2
0 Animiertes Gif anzeigen - NullPointer Exception Allgemeine Java-Themen 19
T Konstruktor löst exception aus Allgemeine Java-Themen 7
KilledByCheese Dezimal nach Hexadezimal rechner wirft seltsame exception Allgemeine Java-Themen 4
V Compiler-Fehler Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: Index: 125, Size: 125 Allgemeine Java-Themen 11
D Codeausführung bevor Exception abgeschlossen ist Allgemeine Java-Themen 11
T FileNotFound Exception Allgemeine Java-Themen 9
L Exception/Error auf JDialog umleiten Allgemeine Java-Themen 2
M A Java Exception has occured. Allgemeine Java-Themen 1
J Exception in thread "main" java.lang.NoClassDefFoundError Allgemeine Java-Themen 4
M Exception in thread "AWT-EventQueue-0" Allgemeine Java-Themen 6
P Input/Output java.util.Scanner in einer Schleife und Exception-Behandlung: Einlesen einer Zahl Allgemeine Java-Themen 4
E A Java Exception Has Occured Allgemeine Java-Themen 4
T Exception handling Allgemeine Java-Themen 7
P lazy loading exception Allgemeine Java-Themen 0
A Interpreter-Fehler OutOfMemory Exception mit Base64 decode Allgemeine Java-Themen 3
S Java Applet Crash - Keine Exception Allgemeine Java-Themen 8
S Best Practice verschiedene Exceptions fangen und neue Exception erzeugen Allgemeine Java-Themen 11
K Exception in thread "AWT-EventQueue-1" Allgemeine Java-Themen 2
K Gepacktes Jar-File gibt beim Doppelklick eine Exception aus Allgemeine Java-Themen 4
P Eigene Exception Klasse Allgemeine Java-Themen 7
N Java Interne Exception Allgemeine Java-Themen 4
B JUnit4 Exception-Test Allgemeine Java-Themen 4
127.0.0.1 SQL Exception, kein Driver Allgemeine Java-Themen 9
S Erste Schritte Exception beendet Schleife nicht - Methode macht trotz throw weiter? Allgemeine Java-Themen 9
R ZIP FileSystem unter Windows wirft exception Allgemeine Java-Themen 7
H java.util.Timer und Funktion mit SQL Exception Allgemeine Java-Themen 5
Ollek Barcode mit Barcode4J erzeugen - Exception Allgemeine Java-Themen 4
Z Concurrent Modification Exception - HashMap (kein remove) Allgemeine Java-Themen 4
E Eigene Exception Klasse erstellen Allgemeine Java-Themen 3
L Variablen IO Exception weil File angeblich nicht exisitert Allgemeine Java-Themen 10
T Exception versus Rückgabeparamter Allgemeine Java-Themen 26
S Exception enableDepthTest Allgemeine Java-Themen 7
M JAXB Reimport zu Hibernate DB -> Exception Allgemeine Java-Themen 3
W Kleine Frage zu Null-Pinter-Exception Allgemeine Java-Themen 21
aze JUnit: Testen ob bestimmte Exception nicht auftritt Allgemeine Java-Themen 18
S Null Pointer Exception bei BufferedReader Allgemeine Java-Themen 4
N Runtime.exec() Exception Problem Allgemeine Java-Themen 3
P Default constructor cannot handle exception type Allgemeine Java-Themen 6
M Objekt prüfen auf null ->Invocation Target Exception??? Allgemeine Java-Themen 2
S Bildaufbau durch Servlet -> Exception Allgemeine Java-Themen 11
E Queue: Wie kann hier ein null-Pointer Exception auftreten?! Allgemeine Java-Themen 11
S Exception beim Schreiben des Dataset in XML Datei Allgemeine Java-Themen 8
M Webstart Exception trotz signierten JARs Allgemeine Java-Themen 3
E Interpreter-Fehler unbekannte Exception Allgemeine Java-Themen 12
B Komische Exception Allgemeine Java-Themen 4
U SwingWorker und Exception Allgemeine Java-Themen 3
B Nullpointer Exception in Array Allgemeine Java-Themen 15
G WebService Exception Allgemeine Java-Themen 3
M Best Practices Exception Handling für eigene library Allgemeine Java-Themen 8
G PermSpace Exception Allgemeine Java-Themen 2
S Invalid Chunk Exception Allgemeine Java-Themen 3
N URLClassLoader Exception Allgemeine Java-Themen 5
Apo Java Sound Mark/Reset Exception Allgemeine Java-Themen 14
M Exception ganz sehen Allgemeine Java-Themen 2
D Problem mit EasyMock und Exception Allgemeine Java-Themen 6
B Exception wird geworfen, ich darf sie aber nicht abfangen. Allgemeine Java-Themen 10
7 Exception wird nicht aufgefangen Allgemeine Java-Themen 8
C Desktop.mail Problem. IO Exception: Failed to open. Allgemeine Java-Themen 3
L [Exception] RSA Verschlüsselung. Allgemeine Java-Themen 16
Final_Striker Exception bei neuem Look und Feel Allgemeine Java-Themen 2
N Exception beim auslesen einer JTable Allgemeine Java-Themen 5
nrg Stilistisch korrektes Exception Handling Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben