Forum: Compiler & IDEs Präprozessor und Mathe


von OldBug (Gast)


Lesenswert?

Hi zusammen!

Bin gerade zum ersten mal darüber gestolpert. Ich weis leider nicht,
wie ich den Präprozessor zum Exponenzieren überrede :(
Folgender Ausdruck bringt nicht das gewünschte Ergebnis:

#define PRESCL (2^(((1 << CS13) | (1 << CS11)) - 1))

Einfacher noch:

#define PRESCL (2^2)

Ergibt 0 (null), sollte 4...

Verwende ich das falsche Symbol?

von Jörg Wunsch (Gast)


Lesenswert?

Wenn Du Dir mal überlegst, daß C selbst keinen Operator fürs
Potenzieren kennt (sondern nur die Funktion pow() in der
Mathematikbibliothek, die mit Gleitkommazahlen arbeitet), dann sollte
der Schluß recht nahe liegen, daß der Präprozessor das einfach mal
nicht kann.

von OldBug (Gast)


Lesenswert?

Hm, schaem ;-)

von OldBug (Gast)


Lesenswert?

Das ist ja richtig mies :(
Man kann das nichtmal durch irgendwelches schieben oder so ersetzen...
Und zwei defines für ein und dasselbe sind irgendwo wieder
fehlerträchtig. Naja, bleibt mir wohl nichts anderes übrig!

von nobody0 (Gast)


Lesenswert?

Der Präprozessor kann das, aber ^ bedeutet EXOR.

Potenzieren kann er mit einem Makro auch:

# define mc_POTENZ(a, b) {int i, foo=a; for(i=0;i<b;i++)a*=foo;}

von OldBug (Gast)


Lesenswert?

Das macht aber nicht der Präprozessor ;-)

Habs mit ner #if..#elif Arie gelöst.

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.