Frage
Ich bin gespannt, ob es irgendwelche Garantien über konstante Faltunggarantierte Mindest Constant Folding in C
in C. getan, wo ich
haben gesuchtThis link auf einer Website, deren Seriosität ist unbekannt für mich macht einen offenen Kommentar:
Alle C-Compiler können Integer-Konstantenausdrücke falten, die nach Makroerweiterung vorhanden sind (ANSI C-Anforderung).
Aber ich sehe nichts in z.B. Die C-Programmiersprache, zweite Ausgabe (von der ich annahm, dass sie gründlich aktualisiert wurde, um alle Details von ANSI C zu berücksichtigen). Aber nachdem ich den Index auf Verweise auf relevante Wörter überprüft habe, habe ich nichts gefunden, was das verspricht. Insbesondere die Seiten 38 und 209 kommen nahe, weil sie sagen, jeder Ausdruck, der zur Kompilierungszeit könnte ausgewertet werden könnte, wo eine Konstante verwendet werden könnte (vielleicht mit einigen Einschränkungen, wenn wir pedantisch genug sind), und es sagt solche Ausdrücke "kann" zur Kompilierzeit ausgewertet werden, nicht "wird"/(irgendein Synonym).
Ich suchte this C89 final draft. Das Wort "falten" und "gefalten" ergab keine Werte, und die Suche "konstanter Ausdruck" erzeugte 63 Treffer, von denen ich etwa die Hälfte überprüfte. Der primäre Teil von Interesse scheint im Grunde das gleiche wie das Buch zu sein (es verwendet das Wort "kann" statt "kann", aber das sind auch in diesem Zusammenhang).
Beide scheinen logisch stark zu meinen, dass jeder ANSI-C-Compiler grundlegende Funktionen zum konstanten Falten haben muss, aber gleichzeitig scheint es kein hartes Verbot zu geben, konstante Ausdrücke in Code zu kompilieren die den Ausdruck zur Laufzeit berechnet (eine solche Implementierung profitiert immer noch von konstanten Ausdrücken, da der Compiler Code generieren kann, der ihn einmal berechnet und dann annimmt, dass sich der Wert nicht ändert und eine solche Implementierung durch Einschränkungen in einer zugrunde liegenden Architektur erzwungen werden kann) zB müssen mehrere RISC-Architekturen entweder zwei Anweisungen verwenden, um bestimmte mögliche Werte zu initialisieren, oder sie von einem Speicherort laden.
Ich suchte auch kurz this C99 final draft, aber "Faltung" ergab ein Ergebnis von keinem Wert, während "gefaltet" und "konstant" hatte mehr als hundert Übereinstimmungen, die ich derzeit nicht die Zeit zum Durchkriechen zuweisen konnte.
Motivation
Ich schrieb dieses Makros für mehr semantische/Absicht Klarheit in einigen Code-Bit-Fummeln:
#define UCHAR_LOW_N_BITS_m(n) (unsigned char)(UCHAR_MAX >> (CHAR_BIT - (n)))
#define UCHAR_NTH_BIT_m(n) (unsigned char)(1 << (n))
..wo n
ist immer ein Ganzzahlliteral. Ich möchte besänftigt sein, um eine beruhigende Stimme zu hören: "Es ist in Ordnung, jeder C-Compiler, der im Entferntesten eine Rolle spielt, wird diese Konstanten für dich falten". (P.S. Ich fragte eine separate Frage darüber, ob UCHAR_NTH_BIT_m
sollte als ob bits start from the 0th or 1st bit, hoffentlich an der richtigen Stelle handeln.)
Und ja, die untere könnte in separate Makros, z.#define UCHAR_1ST_BIT_m (unsigned char)1
durch #define UCHAR_3RD_BIT_m (unsigned char)4
oder wie viele ich im Code auch brauche - und während ich unentschlossen bin, welche von denen besser ist, ist es wahrscheinlich ein strittiger Punkt, denn wenn ich ein guter pedantisch-sprachlicher Anwalt sein will, Typ C Programmierer, ich kann nicht genau das Top vermeiden (muss sicherstellen, dass der Code das Richtige auf diesen DSP/embedded und ancient-Mainframe C-Implementierungen tut).
Es liegt beim Compiler-Entwickler. "Can" ist amerikanisch für "may" und bedeutet, dass Sie dürfen, aber Sie müssen es nicht tun. Und ja, jeder gute Compiler wird es tun. –
Ich glaube nicht, dass die Verwendung von "Can" auf amerikanisches Englisch beschränkt ist. – dreamlax
@ KlasLindbäck: Ich schätze die Klarstellung, aber ich war mir bewusst: Deshalb sagte ich "scheint im Grunde gleich zu sein" - weil ich verstand, dass, obwohl es einen Wortunterschied gab, es im Wesentlichen dasselbe bedeutete. Ich werde es bearbeiten, um die Möglichkeit weiterer Missverständnisse zu verringern. – mtraceur