www.mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik Frage: Float-Berechnung in C


Autor: Eduard (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Morgen zusammen!

Ich habe mal eine Frage - wie wird in C ein Float-Wert behandelt?
Ich berechne folgendes:
dac_test_value = (float) (ma_value / 100.0);

So funktioniert es auch. dac_test_value ist als float deklariert. 
ma_value ist ein uint.

Meine Frage: Wenn ich nicht durch 100.0, sondern nur durch 100 teile, 
dann schneidet er mir die Nachkommastellen ab. Wieso ist das so? Ich 
caste den Wert doch schon extra als float.

Autor: Karl Heinz (kbuchegg) (Moderator)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Eduard schrieb:

> dann schneidet er mir die Nachkommastellen ab. Wieso ist das so? Ich
> caste den Wert doch schon extra als float.


Du castest nicht den Wert.
Du castest das Ergebnis von
   ma_value / 100
und getreu den C-Regeln, wird das als Integer Division durchgeführt, 
wenn ma_value ein uint ist.


  dac_test_value = (float) (ma_value / 100);

* zuerst wird dividiert.
* dann wird gecastet
* dann wird zugewiesen

Genau so steht es da und genau so wird es auch durchgeführt

http://www.mikrocontroller.net/articles/FAQ#Datent...

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.