Forum: Mikrocontroller und Digitale Elektronik Einfacher Code... bin ich zu dumm????


von Daniel (Gast)


Lesenswert?

äh komm mir zwar fast etwas blöde vor das zu fragen, aber hab folgendes
stück code, leider kommt nicht das raus, was ich will... ist uwhf =
65535 werden alles elementes des arrays uwzahlschrieben[] 1, bei allen
anderen zahlen für uwhf werden alle 0!!!!!
äh das macht Null sinn... (P.S. & ist gemäss doku ne bitweise und
verknüpfung).... wiso verhält sich dieses bisschen code so??


uwhf = 47234;
uwindex2 = 1;
for (uwindex = 0; uwindex < 16; uwindex++)
  {
    if(uwhv & uwindex2 > 0)
    {
      uwzahlschreiben[uwindex] = 1;
    }
    else
    {
      uwzahlschreiben[uwindex] = 0;
    }
    if (uwindex2 < 65535)
    {
      uwindex2 = uwindex2 * 2;
    }
  }

gruss
daniel

von Daniel (Gast)


Lesenswert?

ups ok, hab den fehler geseh, gerade als ich den beitrag abgeschickt
hatte... das ganze lässt sich leider nicht mehr löschen...

gruss daniel

von Rufus Τ. F. (rufus) Benutzerseite


Lesenswert?

sizeof (int) == 2?

Dann solltest Du Deine Konstanten mit angehängtem U schreiben. Und
"unsigned int" verwenden.

von Karl heinz B. (kbucheg)


Lesenswert?

> uwhf = 65535 werden alles elementes des arrays uwzahlschrieben[] 1,
> bei allen anderen zahlen für uwhf werden alle 0!!!!!

Mit der Fehlerbeschreibung komme ich nicht klar.
Aber ich rate einfach mal:

> if(uwhv & uwindex2 > 0)

Du als Programmierer liest das als

 if( ( uwhv & uwindex2 ) > 0 )

d.h. die umvh wird mit uwindex2 maskiert und wenn dann
noch gesetzte Bits übrig bleiben, kommt der then-Zweig drann.

Der Compiler liest jedoch was völlig anderes:

 if( uwhv & ( uwindex2 > 0 ) )

uwhv wird und-Maskiert mit einer Maske die entweder 0
oder 1 ist, je nachdem ob uwindex2 größer als 0 ist.

C hat hier bescheuerte Operatoren-Prioritaeten. Wenns das war,
dann Gräm dich nicht: Du bist nicht der Erste der da reingefallen
ist und du wirst nicht der Letzte sein.

von Rolf Magnus (Gast)


Lesenswert?

Ok, nach dreimaligem Lesen habe ich diese auf sehr gewöhnungsbedürftige
Art formulierte Frage immer noch nicht verstanden. Was genau soll
rauskommen und was genau kommt tatsächlich raus? Von welchem Type ist
uwhf?

Was mir so aufgefallen ist:

    if(uwhv & uwindex2 > 0)

Willst du wirklich das Ergebnis der Prüfung, ob uwindex2 größer als 0
ist mit uwhv verUNDen?

von Simon K. (simon) Benutzerseite


Lesenswert?

Tja Leute, wenn mein Programmieren Lehrer immer sagt "Simon, da
brauchst eigentlich keine Klammer, aber ist ja auch egal. Besser eine
zuviel als zu wenig. Und es verbessert die Lesbarkeit" kann ich ihm
immer nur zustimmen mit einem herzlichen "Jap".

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.