Zur Übersicht - INFO - Neueste 50 Beiträge - Neuer Beitrag - Suchen - FAQ - Zum CC1-Forum - Zum CC-Pro-Forum

Wichtig: Bevor Du wegen einem Problem mit der CC2 postest, stelle sicher, daß Du
die neueste OS-Version, die neuseste Compiler-DLL und die neuesten Modulversionen benutzt!
Beachte, daß sich auf der CD zur CC2-Unit/Station auch jetzt noch die ältesten Dateien befinden!
Es gelten folgende Anleitung und Regeln: Regeln CC2Net.de-Forum
Zurück zum Artikel  (Blaue Felder sind Pflichtfelder)


André H.">
Name:   UserID: 
 E-Mail:
Kategorie
Betreff
Homepage:
Link-Titel:
Link-URL:
Cookie für Name, UserID, E-Mail, Homepage-URL setzen
(Erspart die Neueingabe bei Beiträgen und Antworten)
(Zum Löschen des Cookies hier klicken)
Ich nutze:
C-Control II Unit
C164CI-Controllerboard
C-Control II Station
CCRP5 mit CC2-Unit (Conrad Roboter)
CC2-Application-Board
CC2-StarterBoard
CC2-ReglerBoard
eigenes Board
original OS     OSOPT_V2     OSOPT V3.0 OSOPT V3.1

Kommentar:
Einfügen von HTML im Kommentar:

Link einfügen: <a href="LINKURL" target="_blank">LINKTITEL</a>
Bild einfügen: <img src="BILDURL">
Text formatieren: <b>fetter Text</b>  <i>kursiver Text</i> <u>unterstrichener Text</u>
Kombinationen sind auch möglich z.B.: <b><i>fetter & kursiver Text</i></b>
C2 Quellcode formatieren: <code>Quellcode</code>
ASM Quellcode formatieren: <asm>Quellcode</asm>
(Innerhalb eines Quellcodeabschnitts ist kein html möglich.)
Wichtig: Bitte mache Zeilenumbrüche, bevor Du am rechten Rand des Eingabefeldes ankommst !  

> Hallo Reto, > > Das ist kein Bug, sondern normal und logisch. :-) > (Wenn man weiß wie eine Berechnung bei der CC2 funzt) > > Wenn Du zwei Integerwerte miteinander multiplizierst, kommt auch wieder > ein Integerwert raus. > Kurz : > <b>Integer</b> mal <b>Integer</b> ergibt wieder einen <b>Integer</b> > Ist ein Longwert in der Berechnung, kommt auch wieder Long heraus, > genauso ist es bei float. > Bsp: > <b>long</b> mal <b>int</b> ergibt <b>long</b> > <b>float</b> mal <b>int</b> ergibt <b>float</b> > Das ganze gilt natürlich nicht nur für Muliplikation, sondern auch für alle > anderen Operatoren. > > Willst Du also einen Float-Wert bei der Berechnug von zwei nicht floats > erhalten, so mußt du vorher mindestens einen Wert vorher in einer Float-Var > speichern: > > <font face="Courier New" size=2>float f; > int i,j; > > f=i; > f=f*j > > Oder nur mit Long: > > long l; > int i,j; > > l=i; > l=l*j > </font> > > Das hat hoffentlich etwas Licht ins Dunkle gebracht. :-) > > MfG André H. > > > > Beim Rechnen mit verschiedenen Integer-Formaten im Zusammenhang mit > > einem Date/Time Modul habe ich folgenden Bug(?) entdeckt: > > > > Example: > > > > const SECONDS_PER_HOUR = 3600; > > long seconds_per_hour; > > int h; > > long l; > > > > // Init > > seconds_per_hour = SECONDS_PER_HOUR; > > h = 24; > > > > // 3 different ways of the same "long" operation > > // > > l = SECONDS_PER_HOUR * 24; // case 1: correct, l = 86400 > > l = seconds_per_hour * h; // case 2: correct, l = 86400 > > > > // but... > > l = SECONDS_PER_HOUR * h; // case 3: <b>ERROR l = 20864</b> > > > > <b>Bemerkung:</b> > > Es scheint, dass die long-Arithmetik im Fall 3 fehl schlägt. Anstatt eine long-Operation > > auszuführen, wird vermutlich eine int-Operation gemacht und anschliessend ein long-Wert > > zurückgegeben. > > > > Komischerweise funktioniert&#39;s, wenn die beiden Operanden (SECONDS_PER_HOUR, 24) vom Typ > > int (oder einer sogar byte?) sind (Fall 1). > > > > Es funktioniert einigermassen logischerweise auch (Fall 2), wenn die eine "Konstante" > > zuerst einer long-Variable zugewiesen wird. > > > > > > <b>Fragen:</b> > > - Weiss jemand eine Erklärung oder findet das Verhalten gar logisch? > > - Muss bei long-Operationen wirklich immer explizites "type casting" angewendet > > werden (das ja eigentlich nicht einmal in C2 enthalten ist)? > > > > Danke für Eure Unterstützung > > Reto
Dateianhang: (.gif, .png., .jpg, .zip, .rar)
max. 256kB
max. 256kB