www.mikrocontroller.net

Forum: GCC if-abfragen mit mehreren vergleichen..

Autor: anfänger (Gast)
Datum: 04.07.2008 12:44

müssen die inneren abfragen noch einmal geklammert werden?
kommen ohne klammerung ein anderer vergleichswert raus als mit
klammerung?

if(twi_status == 0x08 | twi_status == 0x10)

mfg
Autor: Nico Erfurth (masta79)
Datum: 04.07.2008 12:48

In diesem Fall brauchst du keine Klammern, "==" hat eine höhere
Rangordnung als "|", also wird erst verglichen, dann das oder
ausgeführt.

Wenn du aber anfängst mehrere logische Operationen zu nutzen
solltest/musst du die Blöcke entsprechend klammern.
Autor: nils (Gast)
Datum: 04.07.2008 12:51

Mussten da nich zwei Balken rein?
also z.B.

if(bla == blubb || blo = blobb) { ... }
Autor: Andreas Kaiser (a-k)
Datum: 04.07.2008 12:56

Geht genau genommen beides, sinnvoller und deshalb üblich ist aber "||".
Spätestens bei
   if ((b != 0) & (a / b == 1))
wird der Unterschied zwischen "&" und "&&" wichtig.
Autor: Stefan Ernst (sternst)
Datum: 04.07.2008 13:08

Andreas Kaiser wrote:

> Spätestens bei
>    if ((b != 0) & (a / b == 1))
> wird der Unterschied zwischen "&" und "&&" wichtig.

Nö, auch da sind "&" und "&&" praktisch äquivalent.
Wichtig wird es, wenn einer der Operanten auch größer als 1 sein kann
(z.B. "if (a && b)"), oder der rechte Operant einen Seiteneffekt hat.
Autor: Andreas Kaiser (a-k)
Datum: 04.07.2008 13:14

Stefan Ernst wrote:

>>    if ((b != 0) & (a / b == 1))
>
> Nö, auch da sind "&" und "&&" praktisch äquivalent.

Interessant. Kannte ich bisher anders. Bei "&" werden beide Seiten
berechnet, also wird bei b==0 seelenruhig durch 0 dividiert, was dem
Programm ein jähes Ende bereiten kann. Bei "&&" ist sichergestellt, dass
die rechte Seite nur berechnet wird, wenn die linke Seite zutrifft.

> oder der rechte Operant einen Seiteneffekt hat.

Eben. Er hat.
Autor: Stefan Ernst (sternst)
Datum: 04.07.2008 13:18

> Bei "&&" ist sichergestellt, dass
> die rechte Seite nur berechnet wird, wenn die linke Seite zutrifft.

Ja, das meinte ich mit "oder der rechte Operant einen Seiteneffekt hat".
Aber das mit der Division durch Null habe ich übersehen. (peinlich)
Du hast natürlich Recht!
Autor: yalu (Gast)
Datum: 04.07.2008 13:26

Aus dem Gesetzbuch:

  "Unlike the bitwise binary & operator, the && operator guarantees
  left-to-right evaluation; there is a sequence point after the
  evaluation of the first operand. If the first operand compares equal
  to 0, the second operand is not evaluated."

Auch wenn der rechte Operand keinen Seiteneffekt hat, ist das && meist
vorzuziehen, weil es fast immer Rechenzeit einspart. Außerdem dient es
der Lesbarkeit, wenn man durch die Wahl des Operators ausdrückt, ob
eine logische oder eine bitweise Operation gemacht wird.
Autor: Stefan Ernst (sternst)
Datum: 04.07.2008 13:30

@ yalu:

Ja, das ist klar. Es ging ja auch nur darum, dass ein Programm nicht
immer sofort fehlerhaft ist, wenn der "falsche" Operator benutzt wird.
Autor: Andreas Kaiser (a-k)
Datum: 04.07.2008 13:31

yalu wrote:

> Auch wenn der rechte Operand keinen Seiteneffekt hat, ist das && meist
> vorzuziehen, weil es fast immer Rechenzeit einspart.

Bei Controllern stimmt das. Bei PC-Prozessoren kann das auch andersrum
ausgehen, je nachdem wie gut sich die bei "&&" verwendeten Sprungbefehle
vorhersagen lassen.
Autor: yalu (Gast)
Datum: 04.07.2008 14:00

Da sehe ich gerade, dass der GCC, wenn möglich, das & wie ein &&
behandelt, es sei denn, der rechte Operand hat einen definierten
Seiteneffekt. Da a/b keinen (für b!=0) oder einen undefinierten (für
b==0) Seiteneffekt hat, wird sogar hier die &&-Variante genommen.
Autor: Johnny (Gast)
Datum: 04.07.2008 17:59

Ich kann aus meiner Erfahrung nur empfehlen, möglichst immer Klammern zu
schreiben. Dies dient der besseren Lesbarkeit / Verständnis des Codes
und verhindert damit komische Fehler, die im Nachhinein fast nicht mehr
gefunden werden können, da sie rasch übersehen werden.

Antwort schreiben

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

Wichtige Regeln - erst lesen, dann posten!

  • Suchfunktion und Betreffsuche benutzen - vielleicht gibt es schon einen ähnlichen Beitrag
  • Aussagekräftigen Betreff wählen
  • Im Betreff angeben um welchen Controllertyp es geht (AVR, PIC, ...)
  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang
  • JPEG-Dateien (.jpg) nur für Fotos und Scans verwenden
  • Schaltpläne, Screenshots usw. als PNG oder GIF anhängen

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [pre]vorformatierter Text (z.B. Code in anderen Sprachen)[/pre]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel






webmaster@mikrocontroller.netImpressumWerbung auf Mikrocontroller.net